@riligar/auth-react 1.8.0 → 1.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.esm.js +473 -409
- package/dist/index.esm.js.map +1 -1
- package/dist/index.js +472 -408
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
package/dist/index.esm.js
CHANGED
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
import { create } from 'zustand';
|
|
2
2
|
import { useMemo, useEffect, createContext, useState, useRef } from 'react';
|
|
3
3
|
import { useShallow } from 'zustand/react/shallow';
|
|
4
|
+
import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
|
|
4
5
|
import { Navigate, Outlet } from 'react-router-dom';
|
|
5
6
|
import { Paper, Stack, Image, Title, Text, TextInput, PasswordInput, Anchor, Button, Divider, Group, Center, Loader } from '@mantine/core';
|
|
6
7
|
import { useForm } from '@mantine/form';
|
|
7
|
-
import {
|
|
8
|
+
import { IconMail, IconLock, IconArrowRight, IconBrandGoogle, IconBrandGithub, IconUser, IconSend, IconCheck, IconX, IconRefresh } from '@tabler/icons-react';
|
|
8
9
|
|
|
9
10
|
// Config - pode ser sobrescrita pelo AuthProvider
|
|
10
11
|
// Tenta detectar ambiente Vite, mas falha graciosamente se não existir
|
|
@@ -735,9 +736,10 @@ function AuthProvider({
|
|
|
735
736
|
const contextValue = useMemo(() => ({
|
|
736
737
|
onError
|
|
737
738
|
}), [onError]);
|
|
738
|
-
return /*#__PURE__*/
|
|
739
|
-
value: contextValue
|
|
740
|
-
|
|
739
|
+
return /*#__PURE__*/jsx(AuthContext.Provider, {
|
|
740
|
+
value: contextValue,
|
|
741
|
+
children: children
|
|
742
|
+
});
|
|
741
743
|
}
|
|
742
744
|
|
|
743
745
|
/* Hooks "facade" que a app vai usar */
|
|
@@ -798,7 +800,9 @@ const useApplicationLogo = () => {
|
|
|
798
800
|
};
|
|
799
801
|
|
|
800
802
|
function ProtectedRoute({
|
|
801
|
-
fallback = /*#__PURE__*/
|
|
803
|
+
fallback = /*#__PURE__*/jsx("p", {
|
|
804
|
+
children: "\u231B Carregando..."
|
|
805
|
+
}),
|
|
802
806
|
redirectTo = "/login"
|
|
803
807
|
}) {
|
|
804
808
|
const {
|
|
@@ -806,27 +810,13 @@ function ProtectedRoute({
|
|
|
806
810
|
loading
|
|
807
811
|
} = useAuth();
|
|
808
812
|
if (loading) return fallback;
|
|
809
|
-
if (!user) return /*#__PURE__*/
|
|
813
|
+
if (!user) return /*#__PURE__*/jsx(Navigate, {
|
|
810
814
|
to: redirectTo,
|
|
811
815
|
replace: true
|
|
812
816
|
});
|
|
813
|
-
return /*#__PURE__*/
|
|
817
|
+
return /*#__PURE__*/jsx(Outlet, {});
|
|
814
818
|
}
|
|
815
819
|
|
|
816
|
-
function _extends() {
|
|
817
|
-
return _extends = Object.assign ? Object.assign.bind() : function (n) {
|
|
818
|
-
for (var e = 1; e < arguments.length; e++) {
|
|
819
|
-
var t = arguments[e];
|
|
820
|
-
for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]);
|
|
821
|
-
}
|
|
822
|
-
return n;
|
|
823
|
-
}, _extends.apply(null, arguments);
|
|
824
|
-
}
|
|
825
|
-
|
|
826
|
-
/**
|
|
827
|
-
* Container wrapper para componentes de autenticação
|
|
828
|
-
* Usa Mantine Paper com estilo consistente
|
|
829
|
-
*/
|
|
830
820
|
function AuthCard({
|
|
831
821
|
children,
|
|
832
822
|
title,
|
|
@@ -836,35 +826,37 @@ function AuthCard({
|
|
|
836
826
|
width = 350,
|
|
837
827
|
...props
|
|
838
828
|
}) {
|
|
839
|
-
return /*#__PURE__*/
|
|
829
|
+
return /*#__PURE__*/jsx(Paper, {
|
|
840
830
|
withBorder: true,
|
|
841
831
|
shadow: "md",
|
|
842
832
|
p: 24,
|
|
843
833
|
w: width,
|
|
844
|
-
radius: "md"
|
|
845
|
-
|
|
846
|
-
|
|
847
|
-
|
|
848
|
-
|
|
849
|
-
|
|
850
|
-
|
|
851
|
-
|
|
852
|
-
|
|
853
|
-
|
|
854
|
-
|
|
855
|
-
|
|
856
|
-
|
|
857
|
-
|
|
858
|
-
|
|
859
|
-
|
|
834
|
+
radius: "md",
|
|
835
|
+
...props,
|
|
836
|
+
children: /*#__PURE__*/jsxs(Stack, {
|
|
837
|
+
gap: "sm",
|
|
838
|
+
children: [(logo || title || subtitle) && /*#__PURE__*/jsxs(Stack, {
|
|
839
|
+
gap: "xs",
|
|
840
|
+
children: [logo && /*#__PURE__*/jsx(Image, {
|
|
841
|
+
src: logo,
|
|
842
|
+
alt: "Auth",
|
|
843
|
+
h: logoHeight,
|
|
844
|
+
fit: "contain"
|
|
845
|
+
}), title && /*#__PURE__*/jsx(Title, {
|
|
846
|
+
order: 3,
|
|
847
|
+
children: title
|
|
848
|
+
}), subtitle && /*#__PURE__*/jsx(Text, {
|
|
849
|
+
size: "sm",
|
|
850
|
+
c: "dimmed",
|
|
851
|
+
children: subtitle
|
|
852
|
+
})]
|
|
853
|
+
}), children]
|
|
854
|
+
})
|
|
855
|
+
});
|
|
860
856
|
}
|
|
861
857
|
|
|
862
858
|
var img = "";
|
|
863
859
|
|
|
864
|
-
/**
|
|
865
|
-
* Formulário de Sign In completo com Mantine
|
|
866
|
-
* Suporta email/password, magic link, social login
|
|
867
|
-
*/
|
|
868
860
|
function SignInForm({
|
|
869
861
|
// Configuração
|
|
870
862
|
logo,
|
|
@@ -941,83 +933,98 @@ function SignInForm({
|
|
|
941
933
|
}
|
|
942
934
|
};
|
|
943
935
|
const isLoading = loadingSignIn || loadingMagicLink || loadingResetPassword;
|
|
944
|
-
return /*#__PURE__*/
|
|
936
|
+
return /*#__PURE__*/jsxs(AuthCard, {
|
|
945
937
|
logo: finalLogo,
|
|
946
938
|
title: title,
|
|
947
|
-
subtitle: subtitle
|
|
948
|
-
|
|
949
|
-
|
|
950
|
-
|
|
951
|
-
|
|
952
|
-
|
|
953
|
-
|
|
954
|
-
|
|
955
|
-
|
|
956
|
-
|
|
957
|
-
|
|
958
|
-
|
|
959
|
-
|
|
960
|
-
|
|
961
|
-
|
|
962
|
-
|
|
963
|
-
|
|
964
|
-
|
|
965
|
-
|
|
966
|
-
|
|
967
|
-
|
|
968
|
-
|
|
969
|
-
|
|
970
|
-
|
|
971
|
-
|
|
972
|
-
|
|
973
|
-
|
|
974
|
-
|
|
975
|
-
|
|
976
|
-
|
|
977
|
-
|
|
978
|
-
|
|
979
|
-
|
|
980
|
-
|
|
981
|
-
|
|
982
|
-
|
|
983
|
-
|
|
984
|
-
|
|
985
|
-
|
|
986
|
-
|
|
987
|
-
|
|
988
|
-
|
|
989
|
-
|
|
990
|
-
|
|
991
|
-
|
|
992
|
-
|
|
993
|
-
|
|
994
|
-
|
|
995
|
-
|
|
996
|
-
|
|
997
|
-
|
|
998
|
-
|
|
999
|
-
|
|
1000
|
-
|
|
1001
|
-
|
|
1002
|
-
|
|
1003
|
-
|
|
1004
|
-
|
|
1005
|
-
|
|
1006
|
-
|
|
1007
|
-
|
|
1008
|
-
|
|
1009
|
-
|
|
1010
|
-
|
|
1011
|
-
|
|
1012
|
-
|
|
1013
|
-
|
|
1014
|
-
|
|
1015
|
-
|
|
939
|
+
subtitle: subtitle,
|
|
940
|
+
...cardProps,
|
|
941
|
+
children: [/*#__PURE__*/jsx("form", {
|
|
942
|
+
onSubmit: form.onSubmit(handleSubmit),
|
|
943
|
+
children: /*#__PURE__*/jsxs(Stack, {
|
|
944
|
+
gap: "sm",
|
|
945
|
+
children: [/*#__PURE__*/jsx(TextInput, {
|
|
946
|
+
label: labels.email || 'Email',
|
|
947
|
+
placeholder: labels.emailPlaceholder || 'seu@email.com',
|
|
948
|
+
leftSection: /*#__PURE__*/jsx(IconMail, {
|
|
949
|
+
size: 16
|
|
950
|
+
}),
|
|
951
|
+
...form.getInputProps('email'),
|
|
952
|
+
disabled: isLoading
|
|
953
|
+
}), /*#__PURE__*/jsx(PasswordInput, {
|
|
954
|
+
label: labels.password || 'Senha',
|
|
955
|
+
placeholder: labels.passwordPlaceholder || 'Sua senha',
|
|
956
|
+
leftSection: /*#__PURE__*/jsx(IconLock, {
|
|
957
|
+
size: 16
|
|
958
|
+
}),
|
|
959
|
+
...form.getInputProps('password'),
|
|
960
|
+
disabled: isLoading
|
|
961
|
+
}), showForgotPassword && /*#__PURE__*/jsx(Anchor, {
|
|
962
|
+
size: "sm",
|
|
963
|
+
ta: "right",
|
|
964
|
+
onClick: handleForgotPassword,
|
|
965
|
+
style: {
|
|
966
|
+
cursor: 'pointer'
|
|
967
|
+
},
|
|
968
|
+
c: loadingResetPassword ? 'dimmed' : 'blue',
|
|
969
|
+
children: loadingResetPassword ? labels.sendingReset || 'Enviando...' : labels.forgotPassword || 'Esqueceu a senha?'
|
|
970
|
+
}), /*#__PURE__*/jsx(Button, {
|
|
971
|
+
type: "submit",
|
|
972
|
+
fullWidth: true,
|
|
973
|
+
loading: loadingSignIn,
|
|
974
|
+
rightSection: /*#__PURE__*/jsx(IconArrowRight, {
|
|
975
|
+
size: 16
|
|
976
|
+
}),
|
|
977
|
+
children: labels.signInButton || 'Entrar'
|
|
978
|
+
})]
|
|
979
|
+
})
|
|
980
|
+
}), showMagicLink && /*#__PURE__*/jsxs(Fragment, {
|
|
981
|
+
children: [/*#__PURE__*/jsx(Divider, {
|
|
982
|
+
label: labels.orContinueWith || 'Ou continue com'
|
|
983
|
+
}), /*#__PURE__*/jsx(Button, {
|
|
984
|
+
variant: "light",
|
|
985
|
+
fullWidth: true,
|
|
986
|
+
loading: loadingMagicLink,
|
|
987
|
+
leftSection: /*#__PURE__*/jsx(IconMail, {
|
|
988
|
+
size: 16
|
|
989
|
+
}),
|
|
990
|
+
onClick: handleMagicLink,
|
|
991
|
+
disabled: isLoading || !form.values.email,
|
|
992
|
+
children: labels.magicLinkButton || 'Enviar Link Mágico'
|
|
993
|
+
})]
|
|
994
|
+
}), showSocialLogin && /*#__PURE__*/jsxs(Fragment, {
|
|
995
|
+
children: [/*#__PURE__*/jsx(Divider, {}), /*#__PURE__*/jsxs(Group, {
|
|
996
|
+
grow: true,
|
|
997
|
+
children: [/*#__PURE__*/jsx(Button, {
|
|
998
|
+
variant: "light",
|
|
999
|
+
leftSection: /*#__PURE__*/jsx(IconBrandGoogle, {
|
|
1000
|
+
size: 16
|
|
1001
|
+
}),
|
|
1002
|
+
onClick: () => onSocialLogin?.('google'),
|
|
1003
|
+
disabled: isLoading,
|
|
1004
|
+
children: "Google"
|
|
1005
|
+
}), /*#__PURE__*/jsx(Button, {
|
|
1006
|
+
variant: "light",
|
|
1007
|
+
leftSection: /*#__PURE__*/jsx(IconBrandGithub, {
|
|
1008
|
+
size: 16
|
|
1009
|
+
}),
|
|
1010
|
+
onClick: () => onSocialLogin?.('github'),
|
|
1011
|
+
disabled: isLoading,
|
|
1012
|
+
children: "GitHub"
|
|
1013
|
+
})]
|
|
1014
|
+
})]
|
|
1015
|
+
}), showSignUpLink && /*#__PURE__*/jsx(Center, {
|
|
1016
|
+
children: /*#__PURE__*/jsxs(Text, {
|
|
1017
|
+
size: "sm",
|
|
1018
|
+
c: "dimmed",
|
|
1019
|
+
children: [labels.noAccount || 'Não tem uma conta?', " ", /*#__PURE__*/jsx(Anchor, {
|
|
1020
|
+
href: signUpUrl,
|
|
1021
|
+
children: labels.createAccount || 'Criar conta'
|
|
1022
|
+
})]
|
|
1023
|
+
})
|
|
1024
|
+
})]
|
|
1025
|
+
});
|
|
1016
1026
|
}
|
|
1017
1027
|
|
|
1018
|
-
/**
|
|
1019
|
-
* Formulário de Sign Up com Mantine
|
|
1020
|
-
*/
|
|
1021
1028
|
function SignUpForm({
|
|
1022
1029
|
// Configuração
|
|
1023
1030
|
logo,
|
|
@@ -1065,82 +1072,93 @@ function SignUpForm({
|
|
|
1065
1072
|
onError?.(error);
|
|
1066
1073
|
}
|
|
1067
1074
|
};
|
|
1068
|
-
return /*#__PURE__*/
|
|
1075
|
+
return /*#__PURE__*/jsxs(AuthCard, {
|
|
1069
1076
|
logo: finalLogo,
|
|
1070
1077
|
title: title,
|
|
1071
|
-
subtitle: subtitle
|
|
1072
|
-
|
|
1073
|
-
|
|
1074
|
-
|
|
1075
|
-
|
|
1076
|
-
|
|
1077
|
-
|
|
1078
|
-
|
|
1079
|
-
|
|
1080
|
-
|
|
1081
|
-
|
|
1082
|
-
|
|
1083
|
-
|
|
1084
|
-
|
|
1085
|
-
|
|
1086
|
-
|
|
1087
|
-
|
|
1088
|
-
|
|
1089
|
-
|
|
1090
|
-
|
|
1091
|
-
|
|
1092
|
-
|
|
1093
|
-
|
|
1094
|
-
|
|
1095
|
-
|
|
1096
|
-
|
|
1097
|
-
|
|
1098
|
-
|
|
1099
|
-
|
|
1100
|
-
|
|
1101
|
-
|
|
1102
|
-
|
|
1103
|
-
|
|
1104
|
-
|
|
1105
|
-
|
|
1106
|
-
|
|
1107
|
-
|
|
1108
|
-
|
|
1109
|
-
|
|
1110
|
-
|
|
1111
|
-
|
|
1112
|
-
|
|
1113
|
-
|
|
1114
|
-
|
|
1115
|
-
|
|
1116
|
-
|
|
1117
|
-
|
|
1118
|
-
|
|
1119
|
-
|
|
1120
|
-
|
|
1121
|
-
|
|
1122
|
-
|
|
1123
|
-
|
|
1124
|
-
|
|
1125
|
-
|
|
1126
|
-
|
|
1127
|
-
|
|
1128
|
-
|
|
1129
|
-
|
|
1130
|
-
|
|
1131
|
-
|
|
1132
|
-
|
|
1133
|
-
|
|
1134
|
-
|
|
1135
|
-
|
|
1136
|
-
|
|
1137
|
-
|
|
1138
|
-
|
|
1078
|
+
subtitle: subtitle,
|
|
1079
|
+
...cardProps,
|
|
1080
|
+
children: [/*#__PURE__*/jsx("form", {
|
|
1081
|
+
onSubmit: form.onSubmit(handleSubmit),
|
|
1082
|
+
children: /*#__PURE__*/jsxs(Stack, {
|
|
1083
|
+
gap: "sm",
|
|
1084
|
+
children: [requireName && /*#__PURE__*/jsx(TextInput, {
|
|
1085
|
+
label: labels.name || 'Nome',
|
|
1086
|
+
placeholder: labels.namePlaceholder || 'Seu nome',
|
|
1087
|
+
leftSection: /*#__PURE__*/jsx(IconUser, {
|
|
1088
|
+
size: 16
|
|
1089
|
+
}),
|
|
1090
|
+
...form.getInputProps('name'),
|
|
1091
|
+
disabled: loading
|
|
1092
|
+
}), /*#__PURE__*/jsx(TextInput, {
|
|
1093
|
+
label: labels.email || 'Email',
|
|
1094
|
+
placeholder: labels.emailPlaceholder || 'seu@email.com',
|
|
1095
|
+
leftSection: /*#__PURE__*/jsx(IconMail, {
|
|
1096
|
+
size: 16
|
|
1097
|
+
}),
|
|
1098
|
+
...form.getInputProps('email'),
|
|
1099
|
+
disabled: loading
|
|
1100
|
+
}), /*#__PURE__*/jsx(PasswordInput, {
|
|
1101
|
+
label: labels.password || 'Senha',
|
|
1102
|
+
placeholder: labels.passwordPlaceholder || 'Crie uma senha',
|
|
1103
|
+
leftSection: /*#__PURE__*/jsx(IconLock, {
|
|
1104
|
+
size: 16
|
|
1105
|
+
}),
|
|
1106
|
+
...form.getInputProps('password'),
|
|
1107
|
+
disabled: loading
|
|
1108
|
+
}), /*#__PURE__*/jsx(PasswordInput, {
|
|
1109
|
+
label: labels.confirmPassword || 'Confirmar Senha',
|
|
1110
|
+
placeholder: labels.confirmPasswordPlaceholder || 'Repita a senha',
|
|
1111
|
+
leftSection: /*#__PURE__*/jsx(IconLock, {
|
|
1112
|
+
size: 16
|
|
1113
|
+
}),
|
|
1114
|
+
...form.getInputProps('confirmPassword'),
|
|
1115
|
+
disabled: loading
|
|
1116
|
+
}), /*#__PURE__*/jsx(Button, {
|
|
1117
|
+
type: "submit",
|
|
1118
|
+
fullWidth: true,
|
|
1119
|
+
loading: loading,
|
|
1120
|
+
rightSection: /*#__PURE__*/jsx(IconArrowRight, {
|
|
1121
|
+
size: 16
|
|
1122
|
+
}),
|
|
1123
|
+
children: labels.signUpButton || 'Criar Conta'
|
|
1124
|
+
})]
|
|
1125
|
+
})
|
|
1126
|
+
}), showSocialLogin && /*#__PURE__*/jsxs(Fragment, {
|
|
1127
|
+
children: [/*#__PURE__*/jsx(Divider, {
|
|
1128
|
+
label: labels.orContinueWith || 'Ou continue com'
|
|
1129
|
+
}), /*#__PURE__*/jsxs(Group, {
|
|
1130
|
+
grow: true,
|
|
1131
|
+
children: [/*#__PURE__*/jsx(Button, {
|
|
1132
|
+
variant: "light",
|
|
1133
|
+
leftSection: /*#__PURE__*/jsx(IconBrandGoogle, {
|
|
1134
|
+
size: 16
|
|
1135
|
+
}),
|
|
1136
|
+
onClick: () => onSocialLogin?.('google'),
|
|
1137
|
+
disabled: loading,
|
|
1138
|
+
children: "Google"
|
|
1139
|
+
}), /*#__PURE__*/jsx(Button, {
|
|
1140
|
+
variant: "light",
|
|
1141
|
+
leftSection: /*#__PURE__*/jsx(IconBrandGithub, {
|
|
1142
|
+
size: 16
|
|
1143
|
+
}),
|
|
1144
|
+
onClick: () => onSocialLogin?.('github'),
|
|
1145
|
+
disabled: loading,
|
|
1146
|
+
children: "GitHub"
|
|
1147
|
+
})]
|
|
1148
|
+
})]
|
|
1149
|
+
}), showSignInLink && /*#__PURE__*/jsx(Center, {
|
|
1150
|
+
children: /*#__PURE__*/jsxs(Text, {
|
|
1151
|
+
size: "sm",
|
|
1152
|
+
c: "dimmed",
|
|
1153
|
+
children: [labels.hasAccount || 'Já tem uma conta?', " ", /*#__PURE__*/jsx(Anchor, {
|
|
1154
|
+
href: signInUrl,
|
|
1155
|
+
children: labels.signIn || 'Entrar'
|
|
1156
|
+
})]
|
|
1157
|
+
})
|
|
1158
|
+
})]
|
|
1159
|
+
});
|
|
1139
1160
|
}
|
|
1140
1161
|
|
|
1141
|
-
/**
|
|
1142
|
-
* Formulário para envio de Magic Link
|
|
1143
|
-
*/
|
|
1144
1162
|
function MagicLinkForm({
|
|
1145
1163
|
// Configuração
|
|
1146
1164
|
logo,
|
|
@@ -1179,41 +1197,46 @@ function MagicLinkForm({
|
|
|
1179
1197
|
onError?.(error);
|
|
1180
1198
|
}
|
|
1181
1199
|
};
|
|
1182
|
-
return /*#__PURE__*/
|
|
1200
|
+
return /*#__PURE__*/jsxs(AuthCard, {
|
|
1183
1201
|
logo: finalLogo,
|
|
1184
1202
|
title: title,
|
|
1185
|
-
subtitle: subtitle
|
|
1186
|
-
|
|
1187
|
-
|
|
1188
|
-
|
|
1189
|
-
|
|
1190
|
-
|
|
1191
|
-
|
|
1192
|
-
|
|
1193
|
-
|
|
1194
|
-
|
|
1195
|
-
|
|
1196
|
-
|
|
1197
|
-
|
|
1198
|
-
|
|
1199
|
-
|
|
1200
|
-
|
|
1201
|
-
|
|
1202
|
-
|
|
1203
|
-
|
|
1204
|
-
|
|
1205
|
-
|
|
1206
|
-
|
|
1207
|
-
|
|
1208
|
-
|
|
1209
|
-
|
|
1210
|
-
|
|
1203
|
+
subtitle: subtitle,
|
|
1204
|
+
...cardProps,
|
|
1205
|
+
children: [/*#__PURE__*/jsx("form", {
|
|
1206
|
+
onSubmit: form.onSubmit(handleSubmit),
|
|
1207
|
+
children: /*#__PURE__*/jsxs(Stack, {
|
|
1208
|
+
gap: "sm",
|
|
1209
|
+
children: [/*#__PURE__*/jsx(TextInput, {
|
|
1210
|
+
label: labels.email || 'Email',
|
|
1211
|
+
placeholder: labels.emailPlaceholder || 'seu@email.com',
|
|
1212
|
+
leftSection: /*#__PURE__*/jsx(IconMail, {
|
|
1213
|
+
size: 16
|
|
1214
|
+
}),
|
|
1215
|
+
...form.getInputProps('email'),
|
|
1216
|
+
disabled: loading
|
|
1217
|
+
}), /*#__PURE__*/jsx(Button, {
|
|
1218
|
+
type: "submit",
|
|
1219
|
+
fullWidth: true,
|
|
1220
|
+
loading: loading,
|
|
1221
|
+
leftSection: /*#__PURE__*/jsx(IconSend, {
|
|
1222
|
+
size: 16
|
|
1223
|
+
}),
|
|
1224
|
+
children: labels.sendButton || 'Enviar Link Mágico'
|
|
1225
|
+
})]
|
|
1226
|
+
})
|
|
1227
|
+
}), showSignInLink && /*#__PURE__*/jsx(Center, {
|
|
1228
|
+
children: /*#__PURE__*/jsxs(Text, {
|
|
1229
|
+
size: "sm",
|
|
1230
|
+
c: "dimmed",
|
|
1231
|
+
children: [labels.backTo || 'Voltar para', " ", /*#__PURE__*/jsx(Anchor, {
|
|
1232
|
+
href: signInUrl,
|
|
1233
|
+
children: labels.signIn || 'login com senha'
|
|
1234
|
+
})]
|
|
1235
|
+
})
|
|
1236
|
+
})]
|
|
1237
|
+
});
|
|
1211
1238
|
}
|
|
1212
1239
|
|
|
1213
|
-
/**
|
|
1214
|
-
* Componente de verificação de Magic Link
|
|
1215
|
-
* Extrai token da URL e verifica automaticamente
|
|
1216
|
-
*/
|
|
1217
1240
|
function MagicLinkVerify({
|
|
1218
1241
|
// Configuração
|
|
1219
1242
|
logo,
|
|
@@ -1273,49 +1296,57 @@ function MagicLinkVerify({
|
|
|
1273
1296
|
verify();
|
|
1274
1297
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
1275
1298
|
}, [propToken, redirectTo, redirectDelay]);
|
|
1276
|
-
return /*#__PURE__*/
|
|
1277
|
-
logo: finalLogo
|
|
1278
|
-
|
|
1279
|
-
|
|
1280
|
-
|
|
1281
|
-
|
|
1282
|
-
|
|
1283
|
-
|
|
1284
|
-
|
|
1285
|
-
|
|
1286
|
-
|
|
1287
|
-
|
|
1288
|
-
|
|
1289
|
-
|
|
1290
|
-
|
|
1291
|
-
|
|
1292
|
-
|
|
1293
|
-
|
|
1294
|
-
|
|
1295
|
-
|
|
1296
|
-
|
|
1297
|
-
|
|
1298
|
-
|
|
1299
|
-
|
|
1300
|
-
|
|
1301
|
-
|
|
1302
|
-
|
|
1303
|
-
|
|
1304
|
-
|
|
1305
|
-
|
|
1306
|
-
|
|
1307
|
-
|
|
1308
|
-
|
|
1309
|
-
|
|
1310
|
-
|
|
1311
|
-
|
|
1312
|
-
|
|
1313
|
-
|
|
1299
|
+
return /*#__PURE__*/jsxs(AuthCard, {
|
|
1300
|
+
logo: finalLogo,
|
|
1301
|
+
...cardProps,
|
|
1302
|
+
children: [status === 'verifying' && /*#__PURE__*/jsxs(Stack, {
|
|
1303
|
+
align: "center",
|
|
1304
|
+
gap: "sm",
|
|
1305
|
+
children: [/*#__PURE__*/jsx(Loader, {
|
|
1306
|
+
size: "lg"
|
|
1307
|
+
}), /*#__PURE__*/jsx(Title, {
|
|
1308
|
+
order: 4,
|
|
1309
|
+
children: labels.verifying || 'Verificando Link Mágico'
|
|
1310
|
+
}), /*#__PURE__*/jsx(Text, {
|
|
1311
|
+
size: "sm",
|
|
1312
|
+
c: "dimmed",
|
|
1313
|
+
ta: "center",
|
|
1314
|
+
children: labels.pleaseWait || 'Aguarde enquanto autenticamos você...'
|
|
1315
|
+
})]
|
|
1316
|
+
}), status === 'success' && /*#__PURE__*/jsxs(Stack, {
|
|
1317
|
+
align: "center",
|
|
1318
|
+
gap: "sm",
|
|
1319
|
+
children: [/*#__PURE__*/jsx(IconCheck, {
|
|
1320
|
+
size: 48,
|
|
1321
|
+
color: "var(--mantine-color-green-6)"
|
|
1322
|
+
}), /*#__PURE__*/jsx(Title, {
|
|
1323
|
+
order: 4,
|
|
1324
|
+
children: labels.success || 'Autenticado com Sucesso!'
|
|
1325
|
+
}), /*#__PURE__*/jsx(Text, {
|
|
1326
|
+
size: "sm",
|
|
1327
|
+
c: "dimmed",
|
|
1328
|
+
ta: "center",
|
|
1329
|
+
children: redirectTo ? labels.redirecting || 'Redirecionando...' : labels.authenticated || 'Você está autenticado.'
|
|
1330
|
+
})]
|
|
1331
|
+
}), status === 'error' && /*#__PURE__*/jsxs(Stack, {
|
|
1332
|
+
align: "center",
|
|
1333
|
+
gap: "sm",
|
|
1334
|
+
children: [/*#__PURE__*/jsx(IconX, {
|
|
1335
|
+
size: 48,
|
|
1336
|
+
color: "var(--mantine-color-red-6)"
|
|
1337
|
+
}), /*#__PURE__*/jsx(Title, {
|
|
1338
|
+
order: 4,
|
|
1339
|
+
children: labels.failed || 'Falha na Autenticação'
|
|
1340
|
+
}), /*#__PURE__*/jsx(Text, {
|
|
1341
|
+
size: "sm",
|
|
1342
|
+
c: "dimmed",
|
|
1343
|
+
ta: "center",
|
|
1344
|
+
children: errorMessage || labels.invalidLink || 'O link é inválido ou expirou.'
|
|
1345
|
+
})]
|
|
1346
|
+
})]
|
|
1347
|
+
});
|
|
1314
1348
|
}
|
|
1315
1349
|
|
|
1316
|
-
/**
|
|
1317
|
-
* Formulário para solicitar reset de senha
|
|
1318
|
-
*/
|
|
1319
1350
|
function ForgotPasswordForm({
|
|
1320
1351
|
// Configuração
|
|
1321
1352
|
logo,
|
|
@@ -1354,40 +1385,46 @@ function ForgotPasswordForm({
|
|
|
1354
1385
|
onError?.(error);
|
|
1355
1386
|
}
|
|
1356
1387
|
};
|
|
1357
|
-
return /*#__PURE__*/
|
|
1388
|
+
return /*#__PURE__*/jsxs(AuthCard, {
|
|
1358
1389
|
logo: finalLogo,
|
|
1359
1390
|
title: title,
|
|
1360
|
-
subtitle: subtitle
|
|
1361
|
-
|
|
1362
|
-
|
|
1363
|
-
|
|
1364
|
-
|
|
1365
|
-
|
|
1366
|
-
|
|
1367
|
-
|
|
1368
|
-
|
|
1369
|
-
|
|
1370
|
-
|
|
1371
|
-
|
|
1372
|
-
|
|
1373
|
-
|
|
1374
|
-
|
|
1375
|
-
|
|
1376
|
-
|
|
1377
|
-
|
|
1378
|
-
|
|
1379
|
-
|
|
1380
|
-
|
|
1381
|
-
|
|
1382
|
-
|
|
1383
|
-
|
|
1384
|
-
|
|
1385
|
-
|
|
1391
|
+
subtitle: subtitle,
|
|
1392
|
+
...cardProps,
|
|
1393
|
+
children: [/*#__PURE__*/jsx("form", {
|
|
1394
|
+
onSubmit: form.onSubmit(handleSubmit),
|
|
1395
|
+
children: /*#__PURE__*/jsxs(Stack, {
|
|
1396
|
+
gap: "sm",
|
|
1397
|
+
children: [/*#__PURE__*/jsx(TextInput, {
|
|
1398
|
+
label: labels.email || 'Email',
|
|
1399
|
+
placeholder: labels.emailPlaceholder || 'seu@email.com',
|
|
1400
|
+
leftSection: /*#__PURE__*/jsx(IconMail, {
|
|
1401
|
+
size: 16
|
|
1402
|
+
}),
|
|
1403
|
+
...form.getInputProps('email'),
|
|
1404
|
+
disabled: loading
|
|
1405
|
+
}), /*#__PURE__*/jsx(Button, {
|
|
1406
|
+
type: "submit",
|
|
1407
|
+
fullWidth: true,
|
|
1408
|
+
loading: loading,
|
|
1409
|
+
leftSection: /*#__PURE__*/jsx(IconSend, {
|
|
1410
|
+
size: 16
|
|
1411
|
+
}),
|
|
1412
|
+
children: labels.sendButton || 'Enviar Link de Recuperação'
|
|
1413
|
+
})]
|
|
1414
|
+
})
|
|
1415
|
+
}), showSignInLink && /*#__PURE__*/jsx(Center, {
|
|
1416
|
+
children: /*#__PURE__*/jsxs(Text, {
|
|
1417
|
+
size: "sm",
|
|
1418
|
+
c: "dimmed",
|
|
1419
|
+
children: [labels.rememberedPassword || 'Lembrou a senha?', " ", /*#__PURE__*/jsx(Anchor, {
|
|
1420
|
+
href: signInUrl,
|
|
1421
|
+
children: labels.signIn || 'Entrar'
|
|
1422
|
+
})]
|
|
1423
|
+
})
|
|
1424
|
+
})]
|
|
1425
|
+
});
|
|
1386
1426
|
}
|
|
1387
1427
|
|
|
1388
|
-
/**
|
|
1389
|
-
* Formulário para redefinir senha com token
|
|
1390
|
-
*/
|
|
1391
1428
|
function ResetPasswordForm({
|
|
1392
1429
|
// Configuração
|
|
1393
1430
|
logo,
|
|
@@ -1445,76 +1482,88 @@ function ResetPasswordForm({
|
|
|
1445
1482
|
}
|
|
1446
1483
|
};
|
|
1447
1484
|
if (success) {
|
|
1448
|
-
return /*#__PURE__*/
|
|
1449
|
-
logo: finalLogo
|
|
1450
|
-
|
|
1451
|
-
|
|
1452
|
-
|
|
1453
|
-
|
|
1454
|
-
|
|
1455
|
-
|
|
1456
|
-
|
|
1457
|
-
|
|
1458
|
-
|
|
1459
|
-
|
|
1460
|
-
|
|
1461
|
-
|
|
1462
|
-
|
|
1463
|
-
|
|
1464
|
-
|
|
1465
|
-
|
|
1466
|
-
|
|
1485
|
+
return /*#__PURE__*/jsx(AuthCard, {
|
|
1486
|
+
logo: finalLogo,
|
|
1487
|
+
...cardProps,
|
|
1488
|
+
children: /*#__PURE__*/jsxs(Stack, {
|
|
1489
|
+
align: "center",
|
|
1490
|
+
gap: "sm",
|
|
1491
|
+
children: [/*#__PURE__*/jsx(IconCheck, {
|
|
1492
|
+
size: 48,
|
|
1493
|
+
color: "var(--mantine-color-green-6)"
|
|
1494
|
+
}), /*#__PURE__*/jsx(Title, {
|
|
1495
|
+
order: 4,
|
|
1496
|
+
children: labels.successTitle || 'Senha Redefinida!'
|
|
1497
|
+
}), /*#__PURE__*/jsx(Text, {
|
|
1498
|
+
size: "sm",
|
|
1499
|
+
c: "dimmed",
|
|
1500
|
+
ta: "center",
|
|
1501
|
+
children: labels.successMessage || 'Sua senha foi alterada com sucesso.'
|
|
1502
|
+
}), /*#__PURE__*/jsx(Button, {
|
|
1503
|
+
component: "a",
|
|
1504
|
+
href: signInUrl,
|
|
1505
|
+
fullWidth: true,
|
|
1506
|
+
children: labels.goToSignIn || 'Ir para Login'
|
|
1507
|
+
})]
|
|
1508
|
+
})
|
|
1509
|
+
});
|
|
1467
1510
|
}
|
|
1468
1511
|
if (!token) {
|
|
1469
|
-
return /*#__PURE__*/
|
|
1470
|
-
logo: finalLogo
|
|
1471
|
-
|
|
1472
|
-
|
|
1473
|
-
|
|
1474
|
-
|
|
1475
|
-
|
|
1476
|
-
|
|
1477
|
-
|
|
1478
|
-
|
|
1479
|
-
|
|
1480
|
-
|
|
1481
|
-
|
|
1512
|
+
return /*#__PURE__*/jsx(AuthCard, {
|
|
1513
|
+
logo: finalLogo,
|
|
1514
|
+
...cardProps,
|
|
1515
|
+
children: /*#__PURE__*/jsxs(Stack, {
|
|
1516
|
+
align: "center",
|
|
1517
|
+
gap: "sm",
|
|
1518
|
+
children: [/*#__PURE__*/jsx(Text, {
|
|
1519
|
+
c: "red",
|
|
1520
|
+
children: labels.noToken || 'Token não encontrado na URL'
|
|
1521
|
+
}), /*#__PURE__*/jsx(Button, {
|
|
1522
|
+
component: "a",
|
|
1523
|
+
href: signInUrl,
|
|
1524
|
+
variant: "light",
|
|
1525
|
+
fullWidth: true,
|
|
1526
|
+
children: labels.goToSignIn || 'Voltar para Login'
|
|
1527
|
+
})]
|
|
1528
|
+
})
|
|
1529
|
+
});
|
|
1482
1530
|
}
|
|
1483
|
-
return /*#__PURE__*/
|
|
1531
|
+
return /*#__PURE__*/jsx(AuthCard, {
|
|
1484
1532
|
logo: finalLogo,
|
|
1485
1533
|
title: title,
|
|
1486
|
-
subtitle: subtitle
|
|
1487
|
-
|
|
1488
|
-
|
|
1489
|
-
|
|
1490
|
-
|
|
1491
|
-
|
|
1492
|
-
|
|
1493
|
-
|
|
1494
|
-
|
|
1495
|
-
|
|
1496
|
-
|
|
1497
|
-
|
|
1498
|
-
|
|
1499
|
-
|
|
1500
|
-
|
|
1501
|
-
|
|
1502
|
-
|
|
1503
|
-
|
|
1534
|
+
subtitle: subtitle,
|
|
1535
|
+
...cardProps,
|
|
1536
|
+
children: /*#__PURE__*/jsx("form", {
|
|
1537
|
+
onSubmit: form.onSubmit(handleSubmit),
|
|
1538
|
+
children: /*#__PURE__*/jsxs(Stack, {
|
|
1539
|
+
gap: "sm",
|
|
1540
|
+
children: [/*#__PURE__*/jsx(PasswordInput, {
|
|
1541
|
+
label: labels.newPassword || 'Nova Senha',
|
|
1542
|
+
placeholder: labels.newPasswordPlaceholder || 'Crie uma nova senha',
|
|
1543
|
+
leftSection: /*#__PURE__*/jsx(IconLock, {
|
|
1544
|
+
size: 16
|
|
1545
|
+
}),
|
|
1546
|
+
...form.getInputProps('password'),
|
|
1547
|
+
disabled: loading
|
|
1548
|
+
}), /*#__PURE__*/jsx(PasswordInput, {
|
|
1549
|
+
label: labels.confirmPassword || 'Confirmar Senha',
|
|
1550
|
+
placeholder: labels.confirmPasswordPlaceholder || 'Repita a nova senha',
|
|
1551
|
+
leftSection: /*#__PURE__*/jsx(IconLock, {
|
|
1552
|
+
size: 16
|
|
1553
|
+
}),
|
|
1554
|
+
...form.getInputProps('confirmPassword'),
|
|
1555
|
+
disabled: loading
|
|
1556
|
+
}), /*#__PURE__*/jsx(Button, {
|
|
1557
|
+
type: "submit",
|
|
1558
|
+
fullWidth: true,
|
|
1559
|
+
loading: loading,
|
|
1560
|
+
children: labels.resetButton || 'Redefinir Senha'
|
|
1561
|
+
})]
|
|
1562
|
+
})
|
|
1504
1563
|
})
|
|
1505
|
-
}
|
|
1506
|
-
disabled: loading
|
|
1507
|
-
})), /*#__PURE__*/React.createElement(Button, {
|
|
1508
|
-
type: "submit",
|
|
1509
|
-
fullWidth: true,
|
|
1510
|
-
loading: loading
|
|
1511
|
-
}, labels.resetButton || 'Redefinir Senha'))));
|
|
1564
|
+
});
|
|
1512
1565
|
}
|
|
1513
1566
|
|
|
1514
|
-
/**
|
|
1515
|
-
* Card de verificação de email
|
|
1516
|
-
* Verifica token automaticamente e permite reenvio
|
|
1517
|
-
*/
|
|
1518
1567
|
function VerifyEmailCard({
|
|
1519
1568
|
// Configuração
|
|
1520
1569
|
logo,
|
|
@@ -1604,64 +1653,79 @@ function VerifyEmailCard({
|
|
|
1604
1653
|
onError?.(error);
|
|
1605
1654
|
}
|
|
1606
1655
|
};
|
|
1607
|
-
return /*#__PURE__*/
|
|
1608
|
-
logo: finalLogo
|
|
1609
|
-
|
|
1610
|
-
|
|
1611
|
-
|
|
1612
|
-
|
|
1613
|
-
|
|
1614
|
-
|
|
1615
|
-
|
|
1616
|
-
|
|
1617
|
-
|
|
1618
|
-
|
|
1619
|
-
|
|
1620
|
-
|
|
1621
|
-
|
|
1622
|
-
|
|
1623
|
-
|
|
1624
|
-
|
|
1625
|
-
|
|
1626
|
-
|
|
1627
|
-
|
|
1628
|
-
|
|
1629
|
-
|
|
1630
|
-
|
|
1631
|
-
|
|
1632
|
-
|
|
1633
|
-
|
|
1634
|
-
|
|
1635
|
-
|
|
1636
|
-
|
|
1637
|
-
|
|
1638
|
-
|
|
1639
|
-
|
|
1640
|
-
|
|
1641
|
-
|
|
1642
|
-
|
|
1643
|
-
|
|
1644
|
-
|
|
1645
|
-
|
|
1646
|
-
|
|
1647
|
-
|
|
1648
|
-
|
|
1649
|
-
|
|
1650
|
-
|
|
1651
|
-
|
|
1652
|
-
|
|
1653
|
-
|
|
1654
|
-
|
|
1655
|
-
|
|
1656
|
-
|
|
1657
|
-
|
|
1658
|
-
|
|
1659
|
-
|
|
1660
|
-
|
|
1661
|
-
|
|
1662
|
-
|
|
1663
|
-
|
|
1664
|
-
|
|
1656
|
+
return /*#__PURE__*/jsxs(AuthCard, {
|
|
1657
|
+
logo: finalLogo,
|
|
1658
|
+
...cardProps,
|
|
1659
|
+
children: [status === 'verifying' && /*#__PURE__*/jsxs(Stack, {
|
|
1660
|
+
align: "center",
|
|
1661
|
+
gap: "sm",
|
|
1662
|
+
children: [/*#__PURE__*/jsx(Loader, {
|
|
1663
|
+
size: "lg"
|
|
1664
|
+
}), /*#__PURE__*/jsx(Title, {
|
|
1665
|
+
order: 4,
|
|
1666
|
+
children: labels.verifying || 'Verificando Email'
|
|
1667
|
+
}), /*#__PURE__*/jsx(Text, {
|
|
1668
|
+
size: "sm",
|
|
1669
|
+
c: "dimmed",
|
|
1670
|
+
ta: "center",
|
|
1671
|
+
children: labels.pleaseWait || 'Aguarde enquanto verificamos seu email...'
|
|
1672
|
+
})]
|
|
1673
|
+
}), status === 'missing_token' && /*#__PURE__*/jsxs(Stack, {
|
|
1674
|
+
align: "center",
|
|
1675
|
+
gap: "sm",
|
|
1676
|
+
children: [/*#__PURE__*/jsx(IconMail, {
|
|
1677
|
+
size: 48,
|
|
1678
|
+
color: "var(--mantine-color-blue-6)"
|
|
1679
|
+
}), /*#__PURE__*/jsx(Title, {
|
|
1680
|
+
order: 4,
|
|
1681
|
+
children: labels.verification || 'Verificação de Email'
|
|
1682
|
+
}), /*#__PURE__*/jsx(Text, {
|
|
1683
|
+
size: "sm",
|
|
1684
|
+
c: "dimmed",
|
|
1685
|
+
ta: "center",
|
|
1686
|
+
children: labels.missingToken || 'Para verificar seu conta, clique no link enviado para seu email.'
|
|
1687
|
+
})]
|
|
1688
|
+
}), status === 'success' && /*#__PURE__*/jsxs(Stack, {
|
|
1689
|
+
align: "center",
|
|
1690
|
+
gap: "sm",
|
|
1691
|
+
children: [/*#__PURE__*/jsx(IconCheck, {
|
|
1692
|
+
size: 48,
|
|
1693
|
+
color: "var(--mantine-color-green-6)"
|
|
1694
|
+
}), /*#__PURE__*/jsx(Title, {
|
|
1695
|
+
order: 4,
|
|
1696
|
+
children: labels.success || 'Email Verificado!'
|
|
1697
|
+
}), /*#__PURE__*/jsx(Text, {
|
|
1698
|
+
size: "sm",
|
|
1699
|
+
c: "dimmed",
|
|
1700
|
+
ta: "center",
|
|
1701
|
+
children: redirectTo ? labels.redirecting || 'Redirecionando...' : labels.verified || 'Seu email foi verificado com sucesso.'
|
|
1702
|
+
})]
|
|
1703
|
+
}), status === 'error' && /*#__PURE__*/jsxs(Stack, {
|
|
1704
|
+
align: "center",
|
|
1705
|
+
gap: "sm",
|
|
1706
|
+
children: [/*#__PURE__*/jsx(IconX, {
|
|
1707
|
+
size: 48,
|
|
1708
|
+
color: "var(--mantine-color-red-6)"
|
|
1709
|
+
}), /*#__PURE__*/jsx(Title, {
|
|
1710
|
+
order: 4,
|
|
1711
|
+
children: labels.failed || 'Verificação Falhou'
|
|
1712
|
+
}), /*#__PURE__*/jsx(Text, {
|
|
1713
|
+
size: "sm",
|
|
1714
|
+
c: "dimmed",
|
|
1715
|
+
ta: "center",
|
|
1716
|
+
children: errorMessage || labels.invalidToken || 'O link é inválido ou expirou.'
|
|
1717
|
+
}), (email || user?.email || tokenEmail) && errorMessage?.toLowerCase().includes('expired') && /*#__PURE__*/jsx(Button, {
|
|
1718
|
+
variant: "light",
|
|
1719
|
+
leftSection: /*#__PURE__*/jsx(IconRefresh, {
|
|
1720
|
+
size: 16
|
|
1721
|
+
}),
|
|
1722
|
+
onClick: handleResend,
|
|
1723
|
+
loading: loadingResend,
|
|
1724
|
+
fullWidth: true,
|
|
1725
|
+
children: labels.resend || 'Solicitar novo link'
|
|
1726
|
+
})]
|
|
1727
|
+
})]
|
|
1728
|
+
});
|
|
1665
1729
|
}
|
|
1666
1730
|
|
|
1667
1731
|
export { AuthCard, AuthProvider, ForgotPasswordForm, MagicLinkForm, MagicLinkVerify, ProtectedRoute, ResetPasswordForm, SignInForm, SignUpForm, VerifyEmailCard, configure, decodeJWT, forgotPassword, getApplicationInfo, getCurrentUser, getSession, isAuthenticated, refreshToken, resendVerification, resetPassword, sendMagicLink, signIn, signOut, signUp, socialRedirect, useAuth, useAuthLoading, useAuthStore, useCheckToken, useEmailVerification, useMagicLink, usePasswordReset, useSession, useSignIn, useSignOut, useSignUp, verifyEmail, verifyMagicLink };
|