This commit is contained in:
edsea
2024-12-25 17:05:50 +01:00
commit 1f76a04566
43 changed files with 2542 additions and 0 deletions

128
rss/js/home.js Normal file
View File

@@ -0,0 +1,128 @@
document.addEventListener('DOMContentLoaded', async (v) => {
let countries = await fetchCountries();
// Handlers
let countrySelector = document.getElementById('userCountry');
for(country of countries){
countrySelector.innerHTML += `<option value="${country.text}">${country.text}</option>`;
}
let signupForm = document.getElementById('signup');
signupForm.addEventListener('submit', (e) => {
e.preventDefault();
document.getElementById('spinner').classList.add('show');
// Extract form data
let username = signupForm.querySelector('#username').value;
let dob = signupForm.querySelector('#u_dob').value;
let country = signupForm.querySelector('#userCountry').value;
let gender = signupForm.querySelector('#gender').value;
let email = signupForm.querySelector('#email').value;
let password = signupForm.querySelector('#password').value;
let password2 = signupForm.querySelector('#password2').value;
let tosInput = signupForm.querySelector('#tos');
let tos = tosInput.checked;
// Remove errors
document.getElementById('usernameError').innerText = null;
document.getElementById('countryError').innerText = null;
document.getElementById('emailError').innerText = null;
document.getElementById('dobError').innerText = null;
document.getElementById('genderError').innerText = null;
document.getElementById('passwordError').innerText = null;
document.getElementById('password2Error').innerText = null;
let userData = {
username: username,
country: country,
gender: gender,
email: email,
dob: dob,
password: password,
password2: password2,
acceptTerms: tos
};
let action = 'signup';
let formData = JSON.stringify({
action: action,
userData: userData
});
// Send request
fetch('https://api.stellaamor.com/users.php', {
method: 'POST',
headers: { 'Content-Type': 'application/json' },
body: formData
})
.then(response => {
if(response && response.length){
return response.json();
}else{
return null;
}
})
.then(msg => {
console.log(msg);
// If we have a JSON response, process it; otherwise, assume success
document.getElementById('spinner').classList.remove('show');
if (msg && msg.status === 'fail') {
let errorArea = msg.fail_status;
if (errorArea === 'username') {
document.getElementById('usernameError').innerText = msg.message;
}
if (errorArea === 'country') {
document.getElementById('countryError').innerText = msg.message;
}
if (errorArea === 'email') {
document.getElementById('emailError').innerText = msg.message;
}
if (errorArea === 'dob') {
document.getElementById('dobError').innerText = msg.message;
}
if (errorArea === 'gender') {
document.getElementById('genderError').innerText = msg.message;
}
if (errorArea === 'password') {
document.getElementById('passwordError').innerText = msg.message;
}
if (errorArea === 'password2' || errorArea === 'passwords') {
document.getElementById('password2Error').innerText = msg.message;
}
} else {
// Success: Redirect to signin page
setTimeout(() => {
window.location.href = '/signin';
}, 2000);
}
})
.catch(error => {
console.error('Error during signup:', error);
document.getElementById('errors').innerText = 'An error occurred. Please try again later.';
});
});
// Call init functions
});
async function fetchCountries() {
try {
const response = await fetch('https://restcountries.com/v3.1/all?fields=name');
const data = await response.json();
const countries = data.map(country => ({
text: country.name.common,
val: country.cca2,
})).sort((a, b) => a.text.localeCompare(b.text));
return countries;
} catch (error) {
console.error('Error fetching countries:', error);
return [];
}
}

83
rss/js/login.js Normal file
View File

@@ -0,0 +1,83 @@
document.addEventListener('DOMContentLoaded', async (v) =>{
await isAuth();
let loginForm = document.getElementById('loginForm');
loginForm.addEventListener('submit', async (e) =>{
e.preventDefault();
login();
})
})
// Async login function in vanilla JS
async function login() {
// Set login running state
let loginRunning = true;
let loginError = false;
// Get form data
let username = document.getElementById('username').value;
let password = document.getElementById('password').value;
let postFields = {
userData: {
username: username,
password: password
},
action: 'login'
};
try {
// Send request
const response = await fetch('https://api.stellaamor.com/users.php', {
method: 'POST',
headers: { 'Content-Type': 'application/json' },
credentials: 'include', // To handle cookies
body: JSON.stringify(postFields)
});
const data = await response.json();
if (data.status === 'fail') {
// Display error if login fails
loginError = true;
document.getElementById('loginError').innerText = data.message;
loginRunning = false;
} else {
// Successful login, redirect to /home
loginRunning = false;
setTimeout(() => {
window.location.href = '/home';
// Reset form fields and errors after login
document.getElementById('username').value = '';
document.getElementById('password').value = '';
document.getElementById('loginError').innerText = '';
loginRunning = false;
}, 1500);
}
} catch (error) {
console.error('Login error:', error);
loginError = true;
loginRunning = false;
}
}
// Async authentication check function in vanilla JS
async function isAuth() {
try {
const response = await fetch('https://api.stellaamor.com/users.php?isAuth=true', {
method: 'GET',
credentials: 'include'
});
const data = await response.json();
if (data.status === true) {
window.location.href = '/home';
} else {
return false;
}
} catch (error) {
return false;
}
}

4
rss/js/main.js Normal file
View File

@@ -0,0 +1,4 @@
// Global functions
async function mainFetch(fdata){
}

7
rss/js/menu.js Normal file
View File

@@ -0,0 +1,7 @@
const burger = document.querySelector('.burger');
const navLinks = document.querySelector('.nav-links');
burger.addEventListener('click', () => {
navLinks.classList.toggle('nav-active');
burger.classList.toggle('toggle');
});