-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathauthentication.js
107 lines (95 loc) · 3.19 KB
/
authentication.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
// TODO
/**
* Ver os tipos de erros retornados para realizar os avisos, tanto do createUser quanto do authUser
*/
// import {Hello} from 'interation';
// const foo = Hello();
// console.log(foo);
// Inputs
const email = document.getElementById('email');
const password = document.getElementById('password');
// Button
const createUser = document.getElementById('send');
const createGoogleUser = document.getElementById('createGoogleUser');
const authUser = document.getElementById('authUser');
const logout = document.getElementById('logout');
// Display
// const displayName = document.getElementById("displayName");
const profileName = document.getElementById("profileName");
// Create User
createUser.addEventListener('click', function () {
firebase
.auth()
.createUserWithEmailAndPassword(email.value, password.value) // Promise que vai dar ou não certo
.then(() => alert('Hello ' + email.value))
.catch((err) => {
console.error(err.code);
console.log(err.message);
alert('Falha ao cadastrar, verifique o erro no console.');
});
});
createGoogleUser.addEventListener('click', () => {
const provider = new firebase.auth.GoogleAuthProvider();
signIn(provider);
});
function signIn(provider){
firebase
.auth()
.signInWithPopup(provider)
.then((result) => {
console.log(result);
const token = result.credential.accessToken;
// displayName.innerHTML = 'Bem vindo, ' + result.user.displayName;
})
.catch((err) => {
console.error(err);
alert('Falha na autenticação');
})
}
// Auth User
authUser.addEventListener('click', () => {
firebase
.auth()
.signInWithEmailAndPassword(email.value, password.value)
.then((result) => {
// console.log(result);
// displayName.innerText = 'Hello ' + email.value;
alert('Autenticado ' + email.value);
})
.catch((err) => {
console.error(err.code);
console.log(err.message);
alert('Falha ao autenticar, verifique o erro no console');
});
});
// Logout
logout.addEventListener('click', () => {
firebase
.auth()
.signOut()
.then(() => {
// displayName.innerText = 'Você não está autenticado';
alert('Você deslogou');
window.location = 'index.html';
}, (err) => {
console.error(err);
})
});
// Realtime Listener
firebase
.auth()
.onAuthStateChanged( (user) => {
if (user) {
// User is signed in.
console.log(user);
// window.location = 'index.html';
profileName.innerHTML = user.displayName;
document.getElementById("profilePicture").setAttribute("src", user.photoURL);
// Troca de blocos
document.getElementById("profile").style.display = "block";
document.getElementById("user-form").style.display = "none";
} else {
// No user is signed in.
console.log('not logged in');
}
});