@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.
- package/LICENSE +21 -0
- package/README.md +8 -0
- package/package.json +11 -7
- package/src/auth/Private.tsx +17 -0
- package/src/auth/PrivateRoute.tsx +28 -0
- package/src/auth/UnAuth.tsx +16 -0
- package/src/auth/UnAuthRoute.tsx +30 -0
- package/src/auth/{index.d.ts → index.ts} +1 -2
- package/src/components/ApiAccess.tsx +134 -0
- package/src/components/BackupCodeLoginForm.tsx +314 -0
- package/src/components/BackupCodesForm.tsx +198 -0
- package/src/components/ChangePasswordForm.tsx +182 -0
- package/src/components/ConfirmationDialog.tsx +48 -0
- package/src/components/CurrencyCodeSelector.tsx +60 -0
- package/src/components/CurrencyInput.tsx +80 -0
- package/src/components/DashboardPage.tsx +24 -0
- package/src/components/DropdownMenu.tsx +92 -0
- package/src/components/ExpirationSecondsSelector.tsx +65 -0
- package/src/components/Flag.tsx +53 -0
- package/src/components/ForgotPasswordForm.tsx +120 -0
- package/src/components/LoginForm.tsx +307 -0
- package/src/components/LogoutPage.tsx +21 -0
- package/src/components/RegisterForm.tsx +354 -0
- package/src/components/ResetPasswordForm.tsx +164 -0
- package/src/components/SideMenu.tsx +46 -0
- package/src/components/SideMenuListItem.tsx +74 -0
- package/src/components/TopMenu.tsx +134 -0
- package/src/components/TranslatedTitle.tsx +22 -0
- package/src/components/UserLanguageSelector.tsx +45 -0
- package/src/components/UserMenu.tsx +15 -0
- package/src/components/UserSettingsForm.tsx +328 -0
- package/src/components/VerifyEmailPage.tsx +133 -0
- package/src/components/{index.d.ts → index.ts} +1 -1
- package/src/contexts/AuthProvider.spec.tsx +1060 -0
- package/src/contexts/AuthProvider.tsx +741 -0
- package/src/contexts/I18nProvider.tsx +85 -0
- package/src/contexts/MenuContext.tsx +310 -0
- package/src/contexts/SuiteConfigProvider.tsx +93 -0
- package/src/contexts/ThemeProvider.tsx +67 -0
- package/src/contexts/{index.d.ts → index.ts} +0 -1
- package/src/hooks/{index.d.ts → index.ts} +0 -1
- package/src/hooks/useBackupCodes.ts +85 -0
- package/src/hooks/useEmailVerification.ts +39 -0
- package/src/hooks/useExpiringValue.ts +78 -0
- package/src/hooks/useLocalStorage.ts +18 -0
- package/src/hooks/useUserSettings.ts +216 -0
- package/src/{index.d.ts → index.ts} +1 -1
- package/src/interfaces/IAppConfig.ts +5 -0
- package/src/interfaces/IMenuConfig.ts +11 -0
- package/src/interfaces/IMenuOption.ts +55 -0
- package/src/interfaces/index.ts +3 -0
- package/src/services/__mocks__/authService.ts +14 -0
- package/src/services/api.ts +13 -0
- package/src/services/authService.ts +422 -0
- package/src/services/authenticatedApi.ts +17 -0
- package/src/services/index.ts +3 -0
- package/src/types/MenuType.ts +15 -0
- package/src/types/expirationSeconds.ts +18 -0
- package/src/types/index.ts +1 -0
- package/src/types/translation.ts +20 -0
- package/src/wrappers/BackupCodeLoginWrapper.tsx +35 -0
- package/src/wrappers/BackupCodesWrapper.tsx +28 -0
- package/src/wrappers/ChangePasswordFormWrapper.tsx +31 -0
- package/src/wrappers/LoginFormWrapper.tsx +59 -0
- package/src/wrappers/LogoutPageWrapper.tsx +30 -0
- package/src/wrappers/RegisterFormWrapper.tsx +48 -0
- package/src/wrappers/UserSettingsFormWrapper.tsx +39 -0
- package/src/wrappers/VerifyEmailPageWrapper.tsx +27 -0
- package/src/wrappers/{index.d.ts → index.tsx} +8 -1
- package/src/auth/Private.d.ts +0 -6
- package/src/auth/Private.d.ts.map +0 -1
- package/src/auth/Private.js +0 -14
- package/src/auth/PrivateRoute.d.ts +0 -8
- package/src/auth/PrivateRoute.d.ts.map +0 -1
- package/src/auth/PrivateRoute.js +0 -23
- package/src/auth/UnAuth.d.ts +0 -6
- package/src/auth/UnAuth.d.ts.map +0 -1
- package/src/auth/UnAuth.js +0 -14
- package/src/auth/UnAuthRoute.d.ts +0 -8
- package/src/auth/UnAuthRoute.d.ts.map +0 -1
- package/src/auth/UnAuthRoute.js +0 -22
- package/src/auth/index.d.ts.map +0 -1
- package/src/auth/index.js +0 -10
- package/src/components/ApiAccess.d.ts +0 -16
- package/src/components/ApiAccess.d.ts.map +0 -1
- package/src/components/ApiAccess.js +0 -70
- package/src/components/BackupCodeLoginForm.d.ts +0 -43
- package/src/components/BackupCodeLoginForm.d.ts.map +0 -1
- package/src/components/BackupCodeLoginForm.js +0 -106
- package/src/components/BackupCodesForm.d.ts +0 -26
- package/src/components/BackupCodesForm.d.ts.map +0 -1
- package/src/components/BackupCodesForm.js +0 -108
- package/src/components/ChangePasswordForm.d.ts +0 -26
- package/src/components/ChangePasswordForm.d.ts.map +0 -1
- package/src/components/ChangePasswordForm.js +0 -66
- package/src/components/ConfirmationDialog.d.ts +0 -13
- package/src/components/ConfirmationDialog.d.ts.map +0 -1
- package/src/components/ConfirmationDialog.js +0 -10
- package/src/components/CurrencyCodeSelector.d.ts +0 -9
- package/src/components/CurrencyCodeSelector.d.ts.map +0 -1
- package/src/components/CurrencyCodeSelector.js +0 -31
- package/src/components/CurrencyInput.d.ts +0 -13
- package/src/components/CurrencyInput.d.ts.map +0 -1
- package/src/components/CurrencyInput.js +0 -22
- package/src/components/DashboardPage.d.ts +0 -8
- package/src/components/DashboardPage.d.ts.map +0 -1
- package/src/components/DashboardPage.js +0 -10
- package/src/components/DropdownMenu.d.ts +0 -9
- package/src/components/DropdownMenu.d.ts.map +0 -1
- package/src/components/DropdownMenu.js +0 -56
- package/src/components/ExpirationSecondsSelector.d.ts +0 -13
- package/src/components/ExpirationSecondsSelector.d.ts.map +0 -1
- package/src/components/ExpirationSecondsSelector.js +0 -32
- package/src/components/Flag.d.ts +0 -20
- package/src/components/Flag.d.ts.map +0 -1
- package/src/components/Flag.js +0 -43
- package/src/components/ForgotPasswordForm.d.ts +0 -18
- package/src/components/ForgotPasswordForm.d.ts.map +0 -1
- package/src/components/ForgotPasswordForm.js +0 -54
- package/src/components/LoginForm.d.ts +0 -44
- package/src/components/LoginForm.d.ts.map +0 -1
- package/src/components/LoginForm.js +0 -99
- package/src/components/LogoutPage.d.ts +0 -8
- package/src/components/LogoutPage.d.ts.map +0 -1
- package/src/components/LogoutPage.js +0 -16
- package/src/components/RegisterForm.d.ts +0 -54
- package/src/components/RegisterForm.d.ts.map +0 -1
- package/src/components/RegisterForm.js +0 -105
- package/src/components/ResetPasswordForm.d.ts +0 -23
- package/src/components/ResetPasswordForm.d.ts.map +0 -1
- package/src/components/ResetPasswordForm.js +0 -68
- package/src/components/SideMenu.d.ts +0 -8
- package/src/components/SideMenu.d.ts.map +0 -1
- package/src/components/SideMenu.js +0 -25
- package/src/components/SideMenuListItem.d.ts +0 -13
- package/src/components/SideMenuListItem.d.ts.map +0 -1
- package/src/components/SideMenuListItem.js +0 -44
- package/src/components/TopMenu.d.ts +0 -24
- package/src/components/TopMenu.d.ts.map +0 -1
- package/src/components/TopMenu.js +0 -36
- package/src/components/TranslatedTitle.d.ts +0 -7
- package/src/components/TranslatedTitle.d.ts.map +0 -1
- package/src/components/TranslatedTitle.js +0 -15
- package/src/components/UserLanguageSelector.d.ts +0 -4
- package/src/components/UserLanguageSelector.d.ts.map +0 -1
- package/src/components/UserLanguageSelector.js +0 -31
- package/src/components/UserMenu.d.ts +0 -4
- package/src/components/UserMenu.d.ts.map +0 -1
- package/src/components/UserMenu.js +0 -12
- package/src/components/UserSettingsForm.d.ts +0 -56
- package/src/components/UserSettingsForm.d.ts.map +0 -1
- package/src/components/UserSettingsForm.js +0 -93
- package/src/components/VerifyEmailPage.d.ts +0 -23
- package/src/components/VerifyEmailPage.d.ts.map +0 -1
- package/src/components/VerifyEmailPage.js +0 -61
- package/src/components/index.d.ts.map +0 -1
- package/src/components/index.js +0 -28
- package/src/contexts/AuthProvider.d.ts +0 -152
- package/src/contexts/AuthProvider.d.ts.map +0 -1
- package/src/contexts/AuthProvider.js +0 -446
- package/src/contexts/I18nProvider.d.ts +0 -16
- package/src/contexts/I18nProvider.d.ts.map +0 -1
- package/src/contexts/I18nProvider.js +0 -46
- package/src/contexts/MenuContext.d.ts +0 -20
- package/src/contexts/MenuContext.d.ts.map +0 -1
- package/src/contexts/MenuContext.js +0 -244
- package/src/contexts/SuiteConfigProvider.d.ts +0 -44
- package/src/contexts/SuiteConfigProvider.d.ts.map +0 -1
- package/src/contexts/SuiteConfigProvider.js +0 -43
- package/src/contexts/ThemeProvider.d.ts +0 -15
- package/src/contexts/ThemeProvider.d.ts.map +0 -1
- package/src/contexts/ThemeProvider.js +0 -36
- package/src/contexts/index.d.ts.map +0 -1
- package/src/contexts/index.js +0 -8
- package/src/hooks/index.d.ts.map +0 -1
- package/src/hooks/index.js +0 -8
- package/src/hooks/useBackupCodes.d.ts +0 -15
- package/src/hooks/useBackupCodes.d.ts.map +0 -1
- package/src/hooks/useBackupCodes.js +0 -70
- package/src/hooks/useEmailVerification.d.ts +0 -10
- package/src/hooks/useEmailVerification.d.ts.map +0 -1
- package/src/hooks/useEmailVerification.js +0 -36
- package/src/hooks/useExpiringValue.d.ts +0 -14
- package/src/hooks/useExpiringValue.d.ts.map +0 -1
- package/src/hooks/useExpiringValue.js +0 -53
- package/src/hooks/useLocalStorage.d.ts +0 -2
- package/src/hooks/useLocalStorage.d.ts.map +0 -1
- package/src/hooks/useLocalStorage.js +0 -15
- package/src/hooks/useUserSettings.d.ts +0 -46
- package/src/hooks/useUserSettings.d.ts.map +0 -1
- package/src/hooks/useUserSettings.js +0 -152
- package/src/index.d.ts.map +0 -1
- package/src/index.js +0 -12
- package/src/interfaces/IAppConfig.d.ts +0 -6
- package/src/interfaces/IAppConfig.d.ts.map +0 -1
- package/src/interfaces/IAppConfig.js +0 -2
- package/src/interfaces/IMenuConfig.d.ts +0 -11
- package/src/interfaces/IMenuConfig.d.ts.map +0 -1
- package/src/interfaces/IMenuConfig.js +0 -2
- package/src/interfaces/IMenuOption.d.ts +0 -58
- package/src/interfaces/IMenuOption.d.ts.map +0 -1
- package/src/interfaces/IMenuOption.js +0 -2
- package/src/interfaces/index.d.ts +0 -4
- package/src/interfaces/index.d.ts.map +0 -1
- package/src/interfaces/index.js +0 -6
- package/src/services/__mocks__/authService.d.ts +0 -21
- package/src/services/__mocks__/authService.d.ts.map +0 -1
- package/src/services/__mocks__/authService.js +0 -15
- package/src/services/api.d.ts +0 -3
- package/src/services/api.d.ts.map +0 -1
- package/src/services/api.js +0 -14
- package/src/services/authService.d.ts +0 -72
- package/src/services/authService.d.ts.map +0 -1
- package/src/services/authService.js +0 -347
- package/src/services/authenticatedApi.d.ts +0 -3
- package/src/services/authenticatedApi.d.ts.map +0 -1
- package/src/services/authenticatedApi.js +0 -18
- package/src/services/index.d.ts +0 -4
- package/src/services/index.d.ts.map +0 -1
- package/src/services/index.js +0 -6
- package/src/types/MenuType.d.ts +0 -11
- package/src/types/MenuType.d.ts.map +0 -1
- package/src/types/MenuType.js +0 -12
- package/src/types/expirationSeconds.d.ts +0 -3
- package/src/types/expirationSeconds.d.ts.map +0 -1
- package/src/types/expirationSeconds.js +0 -17
- package/src/types/index.d.ts +0 -2
- package/src/types/index.d.ts.map +0 -1
- package/src/types/index.js +0 -4
- package/src/types/translation.d.ts +0 -10
- package/src/types/translation.d.ts.map +0 -1
- package/src/types/translation.js +0 -9
- package/src/wrappers/BackupCodeLoginWrapper.d.ts +0 -8
- package/src/wrappers/BackupCodeLoginWrapper.d.ts.map +0 -1
- package/src/wrappers/BackupCodeLoginWrapper.js +0 -21
- package/src/wrappers/BackupCodesWrapper.d.ts +0 -7
- package/src/wrappers/BackupCodesWrapper.d.ts.map +0 -1
- package/src/wrappers/BackupCodesWrapper.js +0 -17
- package/src/wrappers/ChangePasswordFormWrapper.d.ts +0 -8
- package/src/wrappers/ChangePasswordFormWrapper.d.ts.map +0 -1
- package/src/wrappers/ChangePasswordFormWrapper.js +0 -21
- package/src/wrappers/LoginFormWrapper.d.ts +0 -9
- package/src/wrappers/LoginFormWrapper.d.ts.map +0 -1
- package/src/wrappers/LoginFormWrapper.js +0 -43
- package/src/wrappers/LogoutPageWrapper.d.ts +0 -9
- package/src/wrappers/LogoutPageWrapper.d.ts.map +0 -1
- package/src/wrappers/LogoutPageWrapper.js +0 -21
- package/src/wrappers/RegisterFormWrapper.d.ts +0 -9
- package/src/wrappers/RegisterFormWrapper.d.ts.map +0 -1
- package/src/wrappers/RegisterFormWrapper.js +0 -26
- package/src/wrappers/UserSettingsFormWrapper.d.ts +0 -8
- package/src/wrappers/UserSettingsFormWrapper.d.ts.map +0 -1
- package/src/wrappers/UserSettingsFormWrapper.js +0 -24
- package/src/wrappers/VerifyEmailPageWrapper.d.ts +0 -8
- package/src/wrappers/VerifyEmailPageWrapper.d.ts.map +0 -1
- package/src/wrappers/VerifyEmailPageWrapper.js +0 -20
- package/src/wrappers/index.d.ts.map +0 -1
- package/src/wrappers/index.js +0 -20
|
@@ -1,446 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.useAuth = exports.AuthProvider = exports.AuthContext = void 0;
|
|
4
|
-
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
-
const ecies_lib_1 = require("@digitaldefiance/ecies-lib");
|
|
6
|
-
const i18n_lib_1 = require("@digitaldefiance/i18n-lib");
|
|
7
|
-
const react_1 = require("react");
|
|
8
|
-
const I18nProvider_1 = require("./I18nProvider");
|
|
9
|
-
const ThemeProvider_1 = require("./ThemeProvider");
|
|
10
|
-
const authService_1 = require("../services/authService");
|
|
11
|
-
const authenticatedApi_1 = require("../services/authenticatedApi");
|
|
12
|
-
const useExpiringValue_1 = require("../hooks/useExpiringValue");
|
|
13
|
-
const useLocalStorage_1 = require("../hooks/useLocalStorage");
|
|
14
|
-
const useUserSettings_1 = require("../hooks/useUserSettings");
|
|
15
|
-
const suite_core_lib_1 = require("@digitaldefiance/suite-core-lib");
|
|
16
|
-
exports.AuthContext = (0, react_1.createContext)({});
|
|
17
|
-
const AuthProviderInner = ({ children, baseUrl, constants, eciesConfig, onLogout }) => {
|
|
18
|
-
const { t, tComponent } = (0, I18nProvider_1.useI18n)();
|
|
19
|
-
const { setColorMode: themeSetPaletteMode, mode: colorMode } = (0, ThemeProvider_1.useTheme)();
|
|
20
|
-
const authService = (0, react_1.useMemo)(() => (0, authService_1.createAuthService)(constants, baseUrl, eciesConfig), [constants, baseUrl, eciesConfig]);
|
|
21
|
-
const authenticatedApi = (0, react_1.useMemo)(() => (0, authenticatedApi_1.createAuthenticatedApiClient)(baseUrl), [baseUrl]);
|
|
22
|
-
// Use the custom hooks for expiring values
|
|
23
|
-
const mnemonicManager = (0, useExpiringValue_1.useExpiringValue)(constants.DefaultExpireMemoryMnemonicSeconds, 'mnemonicExpirationSeconds');
|
|
24
|
-
const walletManager = (0, useExpiringValue_1.useExpiringValue)(constants.DefaultExpireMemoryWalletSeconds, 'walletExpirationSeconds');
|
|
25
|
-
// Use localStorage hook for expiration settings
|
|
26
|
-
const [mnemonicExpirationSeconds, _setMnemonicExpirationSeconds] = (0, useLocalStorage_1.useLocalStorage)('mnemonicExpirationSeconds', constants.DefaultExpireMemoryMnemonicSeconds);
|
|
27
|
-
const [walletExpirationSeconds, _setWalletExpirationSeconds] = (0, useLocalStorage_1.useLocalStorage)('walletExpirationSeconds', constants.DefaultExpireMemoryWalletSeconds);
|
|
28
|
-
const [serverPublicKey, setServerPublicKey] = (0, react_1.useState)(null);
|
|
29
|
-
const [user, setUser] = (0, react_1.useState)(null);
|
|
30
|
-
const [frontendUser, setFrontendUser] = (0, react_1.useState)(null);
|
|
31
|
-
const [isAuthenticated, setIsAuthenticated] = (0, react_1.useState)(false);
|
|
32
|
-
const [isGlobalAdmin, setIsGlobalAdmin] = (0, react_1.useState)(false);
|
|
33
|
-
const [loading, setLoading] = (0, react_1.useState)(true);
|
|
34
|
-
// Separate flag so route guards don't unmount during actions (e.g., register/login)
|
|
35
|
-
const [isCheckingAuth, setIsCheckingAuth] = (0, react_1.useState)(true);
|
|
36
|
-
const [token, setToken] = (0, react_1.useState)(null);
|
|
37
|
-
const [authState, setAuthState] = (0, react_1.useState)(0);
|
|
38
|
-
// Use the user settings hook for settings management
|
|
39
|
-
const { userSettings, setUserSettingAndUpdateSettings } = (0, useUserSettings_1.useUserSettings)({
|
|
40
|
-
authenticatedApi,
|
|
41
|
-
isAuthenticated,
|
|
42
|
-
});
|
|
43
|
-
// Helper functions to calculate remaining time (now provided by the hooks)
|
|
44
|
-
const getMnemonicRemainingTime = mnemonicManager.getRemainingTime;
|
|
45
|
-
const getWalletRemainingTime = walletManager.getRemainingTime;
|
|
46
|
-
// Wrapper functions to match the interface (the localStorage hook handles storage automatically)
|
|
47
|
-
const setMnemonicExpirationSeconds = _setMnemonicExpirationSeconds;
|
|
48
|
-
const setWalletExpirationSeconds = _setWalletExpirationSeconds;
|
|
49
|
-
// Sync user language with i18n provider when the user's saved language changes.
|
|
50
|
-
// Important: do NOT depend on currentLanguage here, or we'll run when the UI
|
|
51
|
-
// language changes and inadvertently revert to the older user.siteLanguage,
|
|
52
|
-
// causing a second update request with English US.
|
|
53
|
-
(0, react_1.useEffect)(() => {
|
|
54
|
-
if (user?.siteLanguage) {
|
|
55
|
-
(async () => {
|
|
56
|
-
await setUserSettingAndUpdateSettings({ siteLanguage: user.siteLanguage });
|
|
57
|
-
})();
|
|
58
|
-
}
|
|
59
|
-
// We intentionally only react to changes in the user's saved language.
|
|
60
|
-
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
61
|
-
}, [user?.siteLanguage]);
|
|
62
|
-
const setMnemonic = (0, react_1.useCallback)((mnemonic, durationSeconds) => {
|
|
63
|
-
const finalDurationSeconds = durationSeconds ?? mnemonicExpirationSeconds;
|
|
64
|
-
// Store the duration to localStorage if provided
|
|
65
|
-
if (durationSeconds !== undefined) {
|
|
66
|
-
_setMnemonicExpirationSeconds(durationSeconds);
|
|
67
|
-
}
|
|
68
|
-
// Only save to storage if a custom duration was provided
|
|
69
|
-
return mnemonicManager.setValue(mnemonic, finalDurationSeconds, durationSeconds !== undefined);
|
|
70
|
-
}, [mnemonicExpirationSeconds, mnemonicManager.setValue, _setMnemonicExpirationSeconds]);
|
|
71
|
-
const setWallet = (0, react_1.useCallback)((wallet, durationSeconds) => {
|
|
72
|
-
const finalDurationSeconds = durationSeconds ?? walletExpirationSeconds;
|
|
73
|
-
// Store the duration to localStorage if provided
|
|
74
|
-
if (durationSeconds !== undefined) {
|
|
75
|
-
_setWalletExpirationSeconds(durationSeconds);
|
|
76
|
-
}
|
|
77
|
-
// Only save to storage if a custom duration was provided
|
|
78
|
-
return walletManager.setValue(wallet, finalDurationSeconds, durationSeconds !== undefined);
|
|
79
|
-
}, [walletExpirationSeconds, walletManager.setValue, _setWalletExpirationSeconds]);
|
|
80
|
-
const clearMnemonic = mnemonicManager.clearValue;
|
|
81
|
-
const clearWallet = walletManager.clearValue;
|
|
82
|
-
const checkAuth = (0, react_1.useCallback)(async () => {
|
|
83
|
-
const token = localStorage.getItem('authToken');
|
|
84
|
-
if (!token) {
|
|
85
|
-
setUser(null);
|
|
86
|
-
setIsAuthenticated(false);
|
|
87
|
-
setLoading(false);
|
|
88
|
-
setIsCheckingAuth(false);
|
|
89
|
-
setToken(null);
|
|
90
|
-
setFrontendUser(null);
|
|
91
|
-
setServerPublicKey(null);
|
|
92
|
-
await setUserSettingAndUpdateSettings(undefined);
|
|
93
|
-
themeSetPaletteMode('light');
|
|
94
|
-
clearMnemonic();
|
|
95
|
-
clearWallet();
|
|
96
|
-
return;
|
|
97
|
-
}
|
|
98
|
-
try {
|
|
99
|
-
const userData = await authService.verifyToken(token);
|
|
100
|
-
if ('error' in userData && typeof userData.error === 'string') {
|
|
101
|
-
setIsAuthenticated(false);
|
|
102
|
-
setToken(null);
|
|
103
|
-
}
|
|
104
|
-
else if ('id' in userData && 'email' in userData) {
|
|
105
|
-
const userDataDTO = userData;
|
|
106
|
-
setUser(userDataDTO);
|
|
107
|
-
setIsGlobalAdmin((userDataDTO).roles.some((r) => r.admin));
|
|
108
|
-
setIsAuthenticated(true);
|
|
109
|
-
setToken(token);
|
|
110
|
-
await setUserSettingAndUpdateSettings({
|
|
111
|
-
darkMode: userDataDTO.darkMode,
|
|
112
|
-
currency: new i18n_lib_1.CurrencyCode(userDataDTO.currency),
|
|
113
|
-
timezone: new i18n_lib_1.Timezone(userDataDTO.timezone),
|
|
114
|
-
siteLanguage: userDataDTO.siteLanguage,
|
|
115
|
-
email: new ecies_lib_1.EmailString(userDataDTO.email),
|
|
116
|
-
directChallenge: userDataDTO.directChallenge,
|
|
117
|
-
});
|
|
118
|
-
}
|
|
119
|
-
}
|
|
120
|
-
catch (error) {
|
|
121
|
-
console.error('Token verification failed:', error);
|
|
122
|
-
setUser(null);
|
|
123
|
-
setIsAuthenticated(false);
|
|
124
|
-
await setUserSettingAndUpdateSettings(undefined);
|
|
125
|
-
localStorage.removeItem('authToken');
|
|
126
|
-
}
|
|
127
|
-
finally {
|
|
128
|
-
setLoading(false);
|
|
129
|
-
setIsCheckingAuth(false);
|
|
130
|
-
}
|
|
131
|
-
}, [authService, clearMnemonic, clearWallet, setUserSettingAndUpdateSettings, themeSetPaletteMode]);
|
|
132
|
-
(0, react_1.useEffect)(() => {
|
|
133
|
-
const token = localStorage.getItem('authToken');
|
|
134
|
-
if (token) {
|
|
135
|
-
(async () => {
|
|
136
|
-
await checkAuth();
|
|
137
|
-
})();
|
|
138
|
-
}
|
|
139
|
-
else {
|
|
140
|
-
setLoading(false);
|
|
141
|
-
setIsCheckingAuth(false);
|
|
142
|
-
}
|
|
143
|
-
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
144
|
-
}, [authState]); // Only run when authState changes (login/logout), not when checkAuth is recreated
|
|
145
|
-
const directLogin = (0, react_1.useCallback)(async (mnemonic, username, email, expireMnemonicSeconds, expireWalletSeconds) => {
|
|
146
|
-
setLoading(true);
|
|
147
|
-
const loginResult = await authService.directLogin(mnemonic, username, email);
|
|
148
|
-
setLoading(false);
|
|
149
|
-
if (typeof loginResult === 'object' &&
|
|
150
|
-
'token' in loginResult &&
|
|
151
|
-
'user' in loginResult &&
|
|
152
|
-
'wallet' in loginResult) {
|
|
153
|
-
setMnemonic(mnemonic, expireMnemonicSeconds);
|
|
154
|
-
setUser(loginResult.user);
|
|
155
|
-
setWallet(loginResult.wallet, expireWalletSeconds);
|
|
156
|
-
setIsAuthenticated(true);
|
|
157
|
-
setAuthState((prev) => prev + 1);
|
|
158
|
-
localStorage.setItem('authToken', loginResult.token);
|
|
159
|
-
localStorage.setItem('user', JSON.stringify(loginResult.user));
|
|
160
|
-
await setUserSettingAndUpdateSettings({
|
|
161
|
-
darkMode: loginResult.user.darkMode,
|
|
162
|
-
currency: new i18n_lib_1.CurrencyCode(loginResult.user.currency),
|
|
163
|
-
timezone: new i18n_lib_1.Timezone(loginResult.user.timezone),
|
|
164
|
-
siteLanguage: loginResult.user.siteLanguage,
|
|
165
|
-
email: new ecies_lib_1.EmailString(loginResult.user.email),
|
|
166
|
-
directChallenge: loginResult.user.directChallenge,
|
|
167
|
-
});
|
|
168
|
-
return loginResult;
|
|
169
|
-
}
|
|
170
|
-
return loginResult;
|
|
171
|
-
}, [authService, setMnemonic, setWallet, setUserSettingAndUpdateSettings]);
|
|
172
|
-
const emailChallengeLogin = (0, react_1.useCallback)(async (mnemonic, token, username, email, expireMnemonicSeconds, expireWalletSeconds) => {
|
|
173
|
-
setLoading(true);
|
|
174
|
-
const loginResult = await authService.emailChallengeLogin(mnemonic, token, username, email);
|
|
175
|
-
setLoading(false);
|
|
176
|
-
if (typeof loginResult === 'object' &&
|
|
177
|
-
'token' in loginResult &&
|
|
178
|
-
'user' in loginResult &&
|
|
179
|
-
'wallet' in loginResult) {
|
|
180
|
-
setMnemonic(mnemonic, expireMnemonicSeconds);
|
|
181
|
-
setUser(loginResult.user);
|
|
182
|
-
setWallet(loginResult.wallet, expireWalletSeconds);
|
|
183
|
-
setIsAuthenticated(true);
|
|
184
|
-
setAuthState((prev) => prev + 1);
|
|
185
|
-
localStorage.setItem('authToken', loginResult.token);
|
|
186
|
-
localStorage.setItem('user', JSON.stringify(loginResult.user));
|
|
187
|
-
await setUserSettingAndUpdateSettings({
|
|
188
|
-
darkMode: loginResult.user.darkMode,
|
|
189
|
-
currency: new i18n_lib_1.CurrencyCode(loginResult.user.currency),
|
|
190
|
-
timezone: new i18n_lib_1.Timezone(loginResult.user.timezone),
|
|
191
|
-
siteLanguage: loginResult.user.siteLanguage,
|
|
192
|
-
email: new ecies_lib_1.EmailString(loginResult.user.email),
|
|
193
|
-
directChallenge: loginResult.user.directChallenge,
|
|
194
|
-
});
|
|
195
|
-
return loginResult;
|
|
196
|
-
}
|
|
197
|
-
return loginResult;
|
|
198
|
-
}, [authService, setMnemonic, setWallet, setUserSettingAndUpdateSettings]);
|
|
199
|
-
const getPasswordLoginService = (0, react_1.useCallback)(() => {
|
|
200
|
-
const eciesService = new ecies_lib_1.ECIESService(eciesConfig);
|
|
201
|
-
return new ecies_lib_1.PasswordLoginService(eciesService, new ecies_lib_1.Pbkdf2Service(ecies_lib_1.Constants.PBKDF2_PROFILES, ecies_lib_1.Constants.ECIES, ecies_lib_1.Constants.PBKDF2));
|
|
202
|
-
}, [eciesConfig]);
|
|
203
|
-
const isBrowserPasswordLoginAvailable = (0, react_1.useCallback)(() => {
|
|
204
|
-
const storedEncryptedPassword = localStorage.getItem('encryptedPassword');
|
|
205
|
-
return !!storedEncryptedPassword;
|
|
206
|
-
}, []);
|
|
207
|
-
const passwordLogin = (0, react_1.useCallback)(async (password, username, email) => {
|
|
208
|
-
if (!isBrowserPasswordLoginAvailable()) {
|
|
209
|
-
return { error: tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Error_Login_PasswordLoginNotSetup), errorType: 'PasswordLoginNotSetup' };
|
|
210
|
-
}
|
|
211
|
-
setLoading(true);
|
|
212
|
-
const passwordLoginService = getPasswordLoginService();
|
|
213
|
-
const { wallet, mnemonic } = await passwordLoginService.getWalletAndMnemonicFromLocalStorageBundle(password);
|
|
214
|
-
const loginResult = await authService.directLogin(mnemonic, username, email);
|
|
215
|
-
setLoading(false);
|
|
216
|
-
setWallet(wallet);
|
|
217
|
-
setMnemonic(mnemonic);
|
|
218
|
-
// Set theme based on user's darkMode preference if login succeeded
|
|
219
|
-
if ('user' in loginResult) {
|
|
220
|
-
await setUserSettingAndUpdateSettings({
|
|
221
|
-
darkMode: loginResult.user.darkMode,
|
|
222
|
-
currency: new i18n_lib_1.CurrencyCode(loginResult.user.currency),
|
|
223
|
-
timezone: new i18n_lib_1.Timezone(loginResult.user.timezone),
|
|
224
|
-
siteLanguage: loginResult.user.siteLanguage,
|
|
225
|
-
email: new ecies_lib_1.EmailString(loginResult.user.email),
|
|
226
|
-
directChallenge: loginResult.user.directChallenge,
|
|
227
|
-
});
|
|
228
|
-
}
|
|
229
|
-
return loginResult;
|
|
230
|
-
}, [authService, getPasswordLoginService, setMnemonic, setWallet, t, tComponent, isBrowserPasswordLoginAvailable, setUserSettingAndUpdateSettings]);
|
|
231
|
-
const refreshToken = (0, react_1.useCallback)(async () => {
|
|
232
|
-
try {
|
|
233
|
-
const result = await authService.refreshToken();
|
|
234
|
-
localStorage.setItem('authToken', result.token);
|
|
235
|
-
localStorage.setItem('user', JSON.stringify(result.user));
|
|
236
|
-
setUser(result.user);
|
|
237
|
-
setIsAuthenticated(true);
|
|
238
|
-
return result;
|
|
239
|
-
}
|
|
240
|
-
catch (error) {
|
|
241
|
-
setUser(null);
|
|
242
|
-
setIsAuthenticated(false);
|
|
243
|
-
localStorage.removeItem('authToken');
|
|
244
|
-
localStorage.removeItem('user');
|
|
245
|
-
throw error;
|
|
246
|
-
}
|
|
247
|
-
}, [authService]);
|
|
248
|
-
const register = (0, react_1.useCallback)(async (username, email, timezone, password) => {
|
|
249
|
-
const registerResult = await authService.register(username, email, timezone, password);
|
|
250
|
-
return registerResult;
|
|
251
|
-
}, [baseUrl]);
|
|
252
|
-
const requestEmailLogin = (0, react_1.useCallback)(async (username, email) => {
|
|
253
|
-
setLoading(true);
|
|
254
|
-
const result = await authService.requestEmailLogin(username, email);
|
|
255
|
-
setLoading(false);
|
|
256
|
-
return result;
|
|
257
|
-
}, [baseUrl]);
|
|
258
|
-
const setUpBrowserPasswordLogin = (0, react_1.useCallback)(async (mnemonic, password, username, email) => {
|
|
259
|
-
setLoading(true);
|
|
260
|
-
const passwordLoginService = getPasswordLoginService();
|
|
261
|
-
try {
|
|
262
|
-
const wallet = await passwordLoginService.setupPasswordLoginLocalStorageBundle(mnemonic, password);
|
|
263
|
-
setLoading(false);
|
|
264
|
-
setWallet(wallet);
|
|
265
|
-
setMnemonic(mnemonic);
|
|
266
|
-
return { success: true, message: tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.PasswordLogin_Setup_Success) };
|
|
267
|
-
}
|
|
268
|
-
catch {
|
|
269
|
-
setLoading(false);
|
|
270
|
-
return { success: false, message: tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.PasswordLogin_Setup_Failure) };
|
|
271
|
-
}
|
|
272
|
-
}, [setMnemonic, setWallet, t, tComponent]);
|
|
273
|
-
const backupCodeLogin = (0, react_1.useCallback)(async (identifier, code, isEmail, recoverMnemonic, newPassword) => {
|
|
274
|
-
setLoading(true);
|
|
275
|
-
const loginResult = await authService.backupCodeLogin(identifier, code, isEmail, recoverMnemonic, newPassword);
|
|
276
|
-
setLoading(false);
|
|
277
|
-
if (typeof loginResult === 'object' && 'token' in loginResult) {
|
|
278
|
-
localStorage.setItem('authToken', loginResult.token);
|
|
279
|
-
if (loginResult.user) {
|
|
280
|
-
setUser(loginResult.user);
|
|
281
|
-
setIsAuthenticated(true);
|
|
282
|
-
await setUserSettingAndUpdateSettings({
|
|
283
|
-
darkMode: loginResult.user.darkMode,
|
|
284
|
-
currency: new i18n_lib_1.CurrencyCode(loginResult.user.currency),
|
|
285
|
-
timezone: new i18n_lib_1.Timezone(loginResult.user.timezone),
|
|
286
|
-
siteLanguage: loginResult.user.siteLanguage,
|
|
287
|
-
email: new ecies_lib_1.EmailString(loginResult.user.email),
|
|
288
|
-
directChallenge: loginResult.user.directChallenge,
|
|
289
|
-
});
|
|
290
|
-
}
|
|
291
|
-
setAuthState((prev) => prev + 1);
|
|
292
|
-
return {
|
|
293
|
-
token: loginResult.token,
|
|
294
|
-
mnemonic: loginResult.mnemonic,
|
|
295
|
-
message: loginResult.message,
|
|
296
|
-
codeCount: loginResult.codeCount,
|
|
297
|
-
};
|
|
298
|
-
}
|
|
299
|
-
return loginResult;
|
|
300
|
-
}, [authService, setUserSettingAndUpdateSettings]);
|
|
301
|
-
const logout = (0, react_1.useCallback)(async () => {
|
|
302
|
-
localStorage.removeItem('user');
|
|
303
|
-
localStorage.removeItem('authToken');
|
|
304
|
-
clearMnemonic();
|
|
305
|
-
setUser(null);
|
|
306
|
-
clearWallet();
|
|
307
|
-
setIsAuthenticated(false);
|
|
308
|
-
await setUserSettingAndUpdateSettings(undefined);
|
|
309
|
-
setAuthState((prev) => prev + 1);
|
|
310
|
-
// Call the optional navigation callback if provided
|
|
311
|
-
if (onLogout) {
|
|
312
|
-
onLogout();
|
|
313
|
-
}
|
|
314
|
-
}, [onLogout, clearMnemonic, clearWallet, setUserSettingAndUpdateSettings]);
|
|
315
|
-
const verifyToken = (0, react_1.useCallback)(async (token) => {
|
|
316
|
-
const requestUser = await authService.verifyToken(token);
|
|
317
|
-
if (typeof requestUser === 'object' && 'error' in requestUser) {
|
|
318
|
-
setIsAuthenticated(false);
|
|
319
|
-
await setUserSettingAndUpdateSettings(undefined);
|
|
320
|
-
return false;
|
|
321
|
-
}
|
|
322
|
-
else {
|
|
323
|
-
setUser(requestUser);
|
|
324
|
-
setIsAuthenticated(true);
|
|
325
|
-
return true;
|
|
326
|
-
}
|
|
327
|
-
}, [authService, setUserSettingAndUpdateSettings]);
|
|
328
|
-
const changePassword = (0, react_1.useCallback)(async (currentPassword, newPassword) => {
|
|
329
|
-
if (!isBrowserPasswordLoginAvailable()) {
|
|
330
|
-
return { error: tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.Error_Login_PasswordLoginNotSetup), errorType: 'PasswordLoginNotSetup' };
|
|
331
|
-
}
|
|
332
|
-
setLoading(true);
|
|
333
|
-
try {
|
|
334
|
-
const passwordLoginService = getPasswordLoginService();
|
|
335
|
-
const { mnemonic, wallet } = await passwordLoginService.getWalletAndMnemonicFromLocalStorageBundle(new ecies_lib_1.SecureString(currentPassword));
|
|
336
|
-
if (!mnemonic) {
|
|
337
|
-
setLoading(false);
|
|
338
|
-
return { error: tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.PasswordLogin_InvalidCurrentPassword), errorType: 'InvalidCurrentPassword' };
|
|
339
|
-
}
|
|
340
|
-
await passwordLoginService.setupPasswordLoginLocalStorageBundle(mnemonic, new ecies_lib_1.SecureString(newPassword));
|
|
341
|
-
setLoading(false);
|
|
342
|
-
setWallet(wallet);
|
|
343
|
-
setMnemonic(mnemonic);
|
|
344
|
-
return { success: true, message: tComponent(suite_core_lib_1.SuiteCoreComponentId, suite_core_lib_1.SuiteCoreStringKey.PasswordChange_Success) };
|
|
345
|
-
}
|
|
346
|
-
catch (error) {
|
|
347
|
-
setLoading(false);
|
|
348
|
-
return { error: 'Password change failed' };
|
|
349
|
-
}
|
|
350
|
-
}, [setMnemonic, setWallet, t, tComponent, isBrowserPasswordLoginAvailable]);
|
|
351
|
-
const contextValue = (0, react_1.useMemo)(() => {
|
|
352
|
-
const setUserAndIsAuthenticated = async (newUser) => {
|
|
353
|
-
setUser(newUser);
|
|
354
|
-
setIsAuthenticated(!!newUser);
|
|
355
|
-
};
|
|
356
|
-
return {
|
|
357
|
-
admin: isGlobalAdmin,
|
|
358
|
-
authState,
|
|
359
|
-
backupCodeLogin,
|
|
360
|
-
changePassword,
|
|
361
|
-
checkAuth,
|
|
362
|
-
clearMnemonic,
|
|
363
|
-
clearWallet,
|
|
364
|
-
colorMode,
|
|
365
|
-
currencyCode: userSettings?.currency,
|
|
366
|
-
directLogin,
|
|
367
|
-
emailChallengeLogin,
|
|
368
|
-
getMnemonicRemainingTime,
|
|
369
|
-
getWalletRemainingTime,
|
|
370
|
-
isAuthenticated,
|
|
371
|
-
isCheckingAuth,
|
|
372
|
-
isBrowserPasswordLoginAvailable,
|
|
373
|
-
loading,
|
|
374
|
-
logout,
|
|
375
|
-
mnemonic: mnemonicManager.value,
|
|
376
|
-
mnemonicExpirationSeconds,
|
|
377
|
-
passwordLogin,
|
|
378
|
-
refreshToken,
|
|
379
|
-
register,
|
|
380
|
-
requestEmailLogin,
|
|
381
|
-
serverPublicKey,
|
|
382
|
-
setMnemonic,
|
|
383
|
-
setMnemonicExpirationSeconds,
|
|
384
|
-
setUpBrowserPasswordLogin,
|
|
385
|
-
setUser: setUserAndIsAuthenticated,
|
|
386
|
-
setUserSetting: setUserSettingAndUpdateSettings,
|
|
387
|
-
setWallet,
|
|
388
|
-
setWalletExpirationSeconds,
|
|
389
|
-
token,
|
|
390
|
-
user: frontendUser,
|
|
391
|
-
userData: user,
|
|
392
|
-
userSettings,
|
|
393
|
-
verifyToken,
|
|
394
|
-
wallet: walletManager.value,
|
|
395
|
-
walletExpirationSeconds,
|
|
396
|
-
};
|
|
397
|
-
}, [
|
|
398
|
-
authenticatedApi,
|
|
399
|
-
authState,
|
|
400
|
-
backupCodeLogin,
|
|
401
|
-
changePassword,
|
|
402
|
-
checkAuth,
|
|
403
|
-
clearMnemonic,
|
|
404
|
-
clearWallet,
|
|
405
|
-
colorMode,
|
|
406
|
-
directLogin,
|
|
407
|
-
emailChallengeLogin,
|
|
408
|
-
frontendUser,
|
|
409
|
-
getMnemonicRemainingTime,
|
|
410
|
-
getWalletRemainingTime,
|
|
411
|
-
isAuthenticated,
|
|
412
|
-
isCheckingAuth,
|
|
413
|
-
isGlobalAdmin,
|
|
414
|
-
isBrowserPasswordLoginAvailable,
|
|
415
|
-
loading,
|
|
416
|
-
logout,
|
|
417
|
-
mnemonicManager.value,
|
|
418
|
-
mnemonicExpirationSeconds,
|
|
419
|
-
passwordLogin,
|
|
420
|
-
refreshToken,
|
|
421
|
-
register,
|
|
422
|
-
requestEmailLogin,
|
|
423
|
-
serverPublicKey,
|
|
424
|
-
setMnemonic,
|
|
425
|
-
setMnemonicExpirationSeconds,
|
|
426
|
-
setUpBrowserPasswordLogin,
|
|
427
|
-
setUserSettingAndUpdateSettings,
|
|
428
|
-
setWallet,
|
|
429
|
-
setWalletExpirationSeconds,
|
|
430
|
-
token,
|
|
431
|
-
user,
|
|
432
|
-
userSettings,
|
|
433
|
-
verifyToken,
|
|
434
|
-
walletManager.value,
|
|
435
|
-
walletExpirationSeconds,
|
|
436
|
-
]);
|
|
437
|
-
return ((0, jsx_runtime_1.jsx)(exports.AuthContext.Provider, { value: contextValue, children: children }));
|
|
438
|
-
};
|
|
439
|
-
const AuthProvider = ({ children, baseUrl, constants, eciesConfig, onLogout }) => {
|
|
440
|
-
return ((0, jsx_runtime_1.jsx)(AuthProviderInner, { baseUrl: baseUrl, constants: constants, eciesConfig: eciesConfig, onLogout: onLogout, children: children }));
|
|
441
|
-
};
|
|
442
|
-
exports.AuthProvider = AuthProvider;
|
|
443
|
-
const useAuth = () => {
|
|
444
|
-
return (0, react_1.useContext)(exports.AuthContext);
|
|
445
|
-
};
|
|
446
|
-
exports.useAuth = useAuth;
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { I18nEngine } from '@digitaldefiance/i18n-lib';
|
|
2
|
-
import { FC, ReactNode } from 'react';
|
|
3
|
-
export interface I18nProviderProps {
|
|
4
|
-
children: ReactNode;
|
|
5
|
-
i18nEngine: I18nEngine;
|
|
6
|
-
onLanguageChange?: (language: string) => Promise<void>;
|
|
7
|
-
}
|
|
8
|
-
export interface I18nContextType {
|
|
9
|
-
t: (key: string, vars?: Record<string, string | number>, language?: string) => string;
|
|
10
|
-
tComponent: <TStringKey extends string>(componentId: string, stringKey: TStringKey, vars?: Record<string, string | number>, language?: string) => string;
|
|
11
|
-
changeLanguage: (language: string) => void;
|
|
12
|
-
currentLanguage: string;
|
|
13
|
-
}
|
|
14
|
-
export declare const I18nProvider: FC<I18nProviderProps>;
|
|
15
|
-
export declare const useI18n: () => I18nContextType;
|
|
16
|
-
//# sourceMappingURL=I18nProvider.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"I18nProvider.d.ts","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-express-suite-react-components/src/contexts/I18nProvider.tsx"],"names":[],"mappings":"AAAA,OAAO,EAIL,UAAU,EAEX,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAiB,EAAE,EAAE,SAAS,EAAqC,MAAM,OAAO,CAAC;AAExF,MAAM,WAAW,iBAAiB;IAChC,QAAQ,EAAE,SAAS,CAAC;IACpB,UAAU,EAAE,UAAU,CAAC;IACvB,gBAAgB,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;CACxD;AAED,MAAM,WAAW,eAAe;IAC9B,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC,EAAE,QAAQ,CAAC,EAAE,MAAM,KAAK,MAAM,CAAC;IACtF,UAAU,EAAE,CAAC,UAAU,SAAS,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,SAAS,EAAE,UAAU,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC,EAAE,QAAQ,CAAC,EAAE,MAAM,KAAK,MAAM,CAAC;IACzJ,cAAc,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,IAAI,CAAC;IAC3C,eAAe,EAAE,MAAM,CAAC;CACzB;AAID,eAAO,MAAM,YAAY,EAAE,EAAE,CAAC,iBAAiB,CAoD9C,CAAC;AAEF,eAAO,MAAM,OAAO,uBAMnB,CAAC"}
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.useI18n = exports.I18nProvider = void 0;
|
|
4
|
-
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
-
const i18n_lib_1 = require("@digitaldefiance/i18n-lib");
|
|
6
|
-
const react_1 = require("react");
|
|
7
|
-
const I18nContext = (0, react_1.createContext)(undefined);
|
|
8
|
-
const I18nProvider = ({ children, i18nEngine, onLanguageChange, }) => {
|
|
9
|
-
const context = i18n_lib_1.GlobalActiveContext.getInstance();
|
|
10
|
-
const [currentLanguage, setCurrentLanguage] = (0, react_1.useState)(context.userLanguage);
|
|
11
|
-
const changeLanguage = (0, react_1.useCallback)(async (language) => {
|
|
12
|
-
const languageDetails = i18n_lib_1.LanguageRegistry.getLanguageByCode(language);
|
|
13
|
-
if (language && languageDetails) {
|
|
14
|
-
context.userLanguage = language;
|
|
15
|
-
i18nEngine.setLanguage(language);
|
|
16
|
-
localStorage.setItem('language', languageDetails.name);
|
|
17
|
-
localStorage.setItem('languageCode', language);
|
|
18
|
-
setCurrentLanguage(language);
|
|
19
|
-
if (onLanguageChange) {
|
|
20
|
-
await onLanguageChange(language);
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
}, [onLanguageChange, i18nEngine, context]);
|
|
24
|
-
const t = (0, react_1.useCallback)((key, vars, language) => {
|
|
25
|
-
return i18nEngine.t(key, vars, language ?? currentLanguage);
|
|
26
|
-
}, [i18nEngine, currentLanguage]);
|
|
27
|
-
const tComponent = (0, react_1.useCallback)((componentId, stringKey, vars, language) => {
|
|
28
|
-
return i18nEngine.translate(componentId, stringKey, vars, language ?? currentLanguage);
|
|
29
|
-
}, [currentLanguage, i18nEngine]);
|
|
30
|
-
const value = {
|
|
31
|
-
t,
|
|
32
|
-
tComponent,
|
|
33
|
-
changeLanguage,
|
|
34
|
-
currentLanguage,
|
|
35
|
-
};
|
|
36
|
-
return (0, jsx_runtime_1.jsx)(I18nContext.Provider, { value: value, children: children });
|
|
37
|
-
};
|
|
38
|
-
exports.I18nProvider = I18nProvider;
|
|
39
|
-
const useI18n = () => {
|
|
40
|
-
const context = (0, react_1.useContext)(I18nContext);
|
|
41
|
-
if (context === undefined) {
|
|
42
|
-
throw new Error('useI18n must be used within an I18nProvider');
|
|
43
|
-
}
|
|
44
|
-
return context;
|
|
45
|
-
};
|
|
46
|
-
exports.useI18n = useI18n;
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import { FC, ReactNode } from 'react';
|
|
2
|
-
import { MenuType } from '../types/MenuType';
|
|
3
|
-
import { IMenuOption } from '../interfaces/IMenuOption';
|
|
4
|
-
import { IMenuConfig } from '../interfaces/IMenuConfig';
|
|
5
|
-
interface MenuProviderProps {
|
|
6
|
-
children: ReactNode;
|
|
7
|
-
menuConfigs?: IMenuConfig[];
|
|
8
|
-
enableBackupCodes?: boolean;
|
|
9
|
-
}
|
|
10
|
-
interface MenuContextType {
|
|
11
|
-
menuOptions: IMenuOption[];
|
|
12
|
-
getMenuOptions: (menuType: MenuType, includeDividers: boolean) => IMenuOption[];
|
|
13
|
-
registerMenuOption: (option: IMenuOption) => () => void;
|
|
14
|
-
registerMenuOptions: (options: IMenuOption[]) => () => void;
|
|
15
|
-
getTopMenus: () => Array<IMenuConfig>;
|
|
16
|
-
}
|
|
17
|
-
export declare const MenuProvider: FC<MenuProviderProps>;
|
|
18
|
-
export declare const useMenu: () => MenuContextType;
|
|
19
|
-
export {};
|
|
20
|
-
//# sourceMappingURL=MenuContext.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"MenuContext.d.ts","sourceRoot":"","sources":["../../../../../packages/digitaldefiance-express-suite-react-components/src/contexts/MenuContext.tsx"],"names":[],"mappings":"AAiBA,OAAO,EACL,EAAE,EACF,SAAS,EAQV,MAAM,OAAO,CAAC;AAGf,OAAO,EAAE,QAAQ,EAAa,MAAM,mBAAmB,CAAC;AAExD,OAAO,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AACxD,OAAO,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AAKxD,UAAU,iBAAiB;IACzB,QAAQ,EAAE,SAAS,CAAC;IACpB,WAAW,CAAC,EAAE,WAAW,EAAE,CAAC;IAC5B,iBAAiB,CAAC,EAAE,OAAO,CAAC;CAC7B;AAED,UAAU,eAAe;IACvB,WAAW,EAAE,WAAW,EAAE,CAAC;IAC3B,cAAc,EAAE,CACd,QAAQ,EAAE,QAAQ,EAClB,eAAe,EAAE,OAAO,KACrB,WAAW,EAAE,CAAC;IACnB,kBAAkB,EAAE,CAAC,MAAM,EAAE,WAAW,KAAK,MAAM,IAAI,CAAC;IACxD,mBAAmB,EAAE,CAAC,OAAO,EAAE,WAAW,EAAE,KAAK,MAAM,IAAI,CAAC;IAC5D,WAAW,EAAE,MAAM,KAAK,CAAC,WAAW,CAAC,CAAC;CACvC;AAID,eAAO,MAAM,YAAY,EAAE,EAAE,CAAC,iBAAiB,CAoP9C,CAAC;AAEF,eAAO,MAAM,OAAO,QAAO,eAM1B,CAAC"}
|