Fixed the calendar

This commit is contained in:
ION606
2022-08-16 14:15:12 -07:00
parent 2f073c0eb2
commit 1e8ed76c18
7 changed files with 337 additions and 177 deletions
+2 -4
View File
@@ -152,7 +152,7 @@
link.innerText = ev.link;
link.onclick = function(event) { event.preventDefault(); window.open(ev.link, '_blank'); }
const timeFull = new Date(Number(evlist[ind].time) + (Number(ev.offset) + 1) * 60000);
const timeFull = new Date(Number(evlist[ind].time) + (Number(ev.offset)) * 60000);
var time = [timeFull.getHours().toString(), timeFull.getMinutes().toString()];
//Make sure it looks like 01:08 and not 1:8
@@ -217,12 +217,10 @@
function sendData(event, inp) {
event.preventDefault();
var serverSettings = JSON.parse(window.localStorage.getItem('serverInfo'));
var serverSettings = JSON.parse(window.sessionStorage.getItem('serverInfo'));
window.opener.location.reload();
if (inp.inp == 'cal') {
// const userId = JSON.parse(window.localStorage.getItem('Id'));
var xhrsess = new XMLHttpRequest();
xhrsess.open('post', 'http://www.selmerbot.com/getSessionInfo/', true);
xhrsess.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8');
+112 -18
View File
@@ -139,6 +139,14 @@
border-color: #000000;
}
.ardpd {
color: inherit;
background-color: rgba(85, 83, 83, 0.2);
}
.ardpd:focus-visible {
color: white;
}
</style>
<!-- Buttons -->
@@ -280,6 +288,7 @@
w.sessionStorage.setItem("evlist", evjs);
w.sessionStorage.setItem('day', day);
w.sessionStorage.setItem('ref', 'guild');
w.sessionStorage.setItem('serverInfo', window.sessionStorage.getItem('serverInfo'));
w.location.reload();
w.document.write('<title>Editing ${(new Date(Number(ev.time)))}</title>');
@@ -296,6 +305,7 @@
w.sessionStorage.setItem("day", day);
w.sessionStorage.setItem('ref', 'guild');
w.sessionStorage.setItem('serverInfo', window.sessionStorage.getItem('serverInfo'));
w.location.reload();
// w.document.write('<title>Editing ${(' + String(day) + ')}</title>');
@@ -374,9 +384,28 @@
</script>
<script>
function getSessionData() {
return new Promise((resolve, reject) => {
var xhrsess = new XMLHttpRequest();
xhrsess.open('post', 'http://www.selmerbot.com/getSessionInfo/', true);
xhrsess.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8');
xhrsess.setRequestHeader('session', window.localStorage.getItem('sessionId'));
//Reminder that this will return a map of strings (you'll have to use JSON.parse() again)
xhrsess.onloadend = (e) => {
resolve(JSON.parse(xhrsess.response));
}
xhrsess.send();
});
}
//Maybe pre-load the channels in the server into local storage for accessing when chosing the welcome/logging channels?
window.onload = () => {
var serverSettings = JSON.parse(window.localStorage.getItem('serverInfo'));
const serverInfoPromise = getSessionData();
serverInfoPromise.then((sessionInfo) => {
const serverInfo = JSON.parse(sessionInfo.currentServer);
var serverSettings = JSON.parse(serverInfo.serverSettings);
if (!serverSettings) {
alert("Please log in to continue");
@@ -388,7 +417,7 @@
}
//Get serverId instead of the userId
const id = serverSettings.Id;
const id = serverInfo.Id;
//Check if the user has premium
var xhrverify = new XMLHttpRequest();
@@ -399,14 +428,16 @@
xhrverify.setRequestHeader('userId', id);
xhrverify.onloadend = (e) => {
//Load the channels
var xhr = new XMLHttpRequest();
xhr.open('get', `http://www.selmerbot.com/getChannels/`, true);
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8');
xhr.setRequestHeader('serverNumber', id);
xhr.onloadend = (e) => {
// //Load the channels
// var xhr = new XMLHttpRequest();
// xhr.open('get', `http://www.selmerbot.com/getChannels/`, true);
// xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8');
// xhr.setRequestHeader('serverNumber', id);
// xhr.onloadend = (e) => {
//Channel Section
const channels = JSON.parse(xhr.response);
const channels = JSON.parse(serverInfo.channels);
const roles = JSON.parse(serverInfo.roles);
// console.log(channels.text);
// window.localStorage.setItem('channels', (xhr.response));
@@ -422,6 +453,10 @@
optwelcome.value = channel.id;
optwelcome.innerHTML = channel.name;
var optann = document.createElement('option');
optann.value = channel.id;
optann.innerHTML = channel.name;
if (serverSettings.WELCOME.welcomechannel == optwelcome.value) {
optwelcome.setAttribute('selected', '');
}
@@ -431,12 +466,37 @@
// optlog.selected = serverSettings.LOG.logchannel;
}
if (serverSettings.announcement.channel == optann.value) {
optann.setAttribute('selected', '');
}
document.getElementById('logchanneldropdown').appendChild(optlog);
document.getElementById('welcomechanneldropdown').appendChild(optwelcome);
document.getElementById('achanneldropdown').appendChild(optann);
}
}
const ard = document.getElementById('aroledropdown');
roles.forEach((role) => {
var opt = document.createElement('option');
opt.value = role.Id;
opt.innerHTML = role.name;
// opt.style += `background-color: ${role.color + '33'};`;
if (role.color == '#000000') {
opt.style = 'color: white';
}
else {
opt.style = `color: ${role.color}; background-color: ${role.color + '33'};`;
}
if (serverSettings.announcement.role == role.Id) {
opt.setAttribute('selected', '');
}
ard.appendChild(opt);
});
// document.getElementById('body').classList.replace('hide', 'show');
//Welcome section
@@ -454,8 +514,8 @@
// document.getElementById('lc').setAttribute('value', lc);
// document.getElementById('ls').children[ls].checked = true; //Doesn't work
}
xhr.send();
// }
// xhr.send();
//#region Calendar
@@ -510,18 +570,21 @@
}
xhrverify.send();
});
}
function logout() {
window.localStorage.clear();
window.sessionStorage.clear();
var xhr = new XMLHttpRequest();
xhr.open('post', 'http://www.selmerbot.com/logout/', true);
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8');
xhr.setRequestHeader('sessionid', window.localStorage.getItem('sessionId'));
xhr.onloadend = (e) => { window.location.href = 'index.html'; }
xhr.onloadend = (e) => {
window.localStorage.clear();
window.sessionStorage.clear();
window.location.href = 'index.html';
}
xhr.send();
}
</script>
@@ -561,7 +624,11 @@
b.classList.replace('saved', 'saving');
b.innerText = 'SAVING';
var serverSettings = JSON.parse(window.localStorage.getItem('serverInfo'));
const sessionInfoPromise = getSessionData();
sessionInfoPromise.then((sessionInfo) => {
var serverInfo = JSON.parse(sessionInfo.currentServer);
// var serverInfo = JSON.parse(window.sessionStorage.getItem('serverInfo'));
var serverSettings = JSON.parse(serverInfo.serverSettings);
if (inp.inp == 'logs') {
const ls = document.getElementsByName('ls');
@@ -579,6 +646,10 @@
kl = true;
}
serverSettings.LOG.keepLogs = kl;
} else if (inp.inp == 'announcement') {
serverSettings.announcement.channel = document.getElementById('achanneldropdown').value || null;
serverSettings.announcement.role = document.getElementById('aroledropdown').value || null;
console.log(serverSettings.announcement);
} else {
serverSettings.WELCOME.welcomechannel = document.getElementById('welcomechanneldropdown').value || null;
serverSettings.WELCOME.welcomemessage = document.getElementById('wm').value || null;
@@ -592,9 +663,20 @@
xhr.onloadend = (e) => {
if (xhr.response == 'DONE') {
//Change the current server data
var xhrs = new XMLHttpRequest();
xhrs.open('post', 'http://www.selmerbot.com/setCurrentServer/', true);
xhrs.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8');
xhrs.setRequestHeader('serverNumber', serverInfo.Id);
xhrs.setRequestHeader('sessionid', window.localStorage.getItem("sessionId"));
xhrs.onloadend = (e) => {
if (xhrs.response != 'OK') { alert("Uh Oh! There's been a problem!\nError Code: " + xhrs.response); }
b.classList.replace('saving', 'saved');
b.innerText = 'SAVED';
window.localStorage.setItem('serverInfo', JSON.stringify(serverSettings));
window.sessionStorage.setItem('serverInfo', JSON.stringify(serverSettings));
window.location.reload();
}
xhrs.send();
} else {
b.classList.replace('saving', 'failed');
b.innerText = 'FAILED';
@@ -602,6 +684,7 @@
}
xhr.send(JSON.stringify(serverSettings));
});
}
</script>
</head>
@@ -761,8 +844,19 @@
<tbody id="calbody" style="color: black;">
</tbody>
</table>
<!-- <input type="submit" value="Submit", class="submitButton" onclick="sendData(event, { 'inp': 'cal' })"> -->
</table><br><br>
<label for="ardpd" style="margin-top: 30px;">Select your event ping role</label>
<select id="aroledropdown" name="ardpd" class="form-select mb-5 ardpd" aria-label="Default select example">
<option selected=""></option>
</select>
<label class="ps-1" for="acd">Event Channel Name:</label>
<select id="achanneldropdown" name="acd" class="form-select mb-5">
<option selected=""></option>
</select>
<input type="submit" value="Submit", class="submitButton" onclick="sendData(event, { 'inp': 'announcement' })">
</form>
</div>
+8 -4
View File
@@ -235,8 +235,10 @@
xhr.setRequestHeader('userId', window.sessionStorage.getItem('Id'));
xhr.onloadend = (e) => {
//Maybe have an alert for logged in?
//No need
window.localStorage.removeItem("Id");
window.localStorage.setItem('sessionId', xhr.response);
document.getElementById('alertrow').style = "";
window.location.href = "index.html";
@@ -272,14 +274,16 @@
}
function logout() {
window.localStorage.clear();
window.sessionStorage.clear();
var xhr = new XMLHttpRequest();
xhr.open('post', 'http://www.selmerbot.com/logout/', true);
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8');
xhr.setRequestHeader('sessionid', window.localStorage.getItem('sessionId'));
xhr.onloadend = (e) => { window.location.href = 'index.html'; }
xhr.onloadend = (e) => {
window.localStorage.clear();
window.sessionStorage.clear();
window.location.href = 'index.html';
}
xhr.send();
}
</script>
+62 -1
View File
@@ -74,7 +74,7 @@ app.post('/user', async(request, response) => {
const sessionId = uuidv4();
const dbo = client.db('main').collection('sessions');
dbo.insertOne({ sessionId: sessionId, userId: id, guilds: JSON.stringify(guilds) });
dbo.insertOne({ sessionId: sessionId, userId: id, guilds: JSON.stringify(guilds), currentServer: null });
response.send(sessionId);
});
@@ -152,6 +152,66 @@ app.get('/getChannels', async (req, res) => {
});
app.get('/temp.html', async (req, res) => { return res.sendFile('temp.html', { root: '.' }); });
//Headers: servernumber, sessionid
app.post('/setCurrentServer', async (req, res) => {
try {
const id = req.headers.servernumber;
if (id) {
const obj = {};
const arr = {text: [], voice: []};
const guild = bot.guilds.cache.get(id);
const roles = [];
guild.roles.cache.filter((role) => { return(!role.managed) }).forEach((role) => {
let newObj = {};
newObj.Id = role.id;
newObj.name = role.name;
newObj.color = role.hexColor;
roles.push(newObj);
});
const channels = guild.channels.cache;
channels.forEach((channel) => {
const type = channel.type;
if (type == 'GUILD_TEXT') {
arr.text.push({ name: channel.name, id: channel.id });
} else if (type == 'GUILD_VOICE') {
arr.voice.push({ name: channel.name, id: channel.id });
}
});
connection.then((client) => {
const dbo = client.db(id).collection('SETUP');
dbo.find().toArray(async (err, docs) => {
const m = new Map();
m.set('Id', id);
await Promise.all(docs.map(async (doc) => {
m.set(doc._id, doc);
})).then(() => {
obj['Id'] = id;
obj['roles'] = JSON.stringify(roles);
obj['channels'] = JSON.stringify(arr);
obj['serverSettings'] = JSON.stringify(Object.fromEntries(m));
const dbo = client.db('main').collection('sessions');
dbo.updateOne({ sessionId: req.headers.sessionid }, {$set: { currentServer: JSON.stringify(obj) }});
res.sendStatus(200);
});
})
});
}
} catch (err) {
console.error(err);
res.sendStatus(500);
}
});
app.get('/getCal', async (req, res) => {
const userId = req.headers.userid || false;
const guildId = req.headers.guildid || false;
@@ -310,6 +370,7 @@ app.post('/sendData', async (req, res) => {
await dbo.updateOne({ _id: 'WELCOME' }, {$set: { welcomechannel: pref.WELCOME.welcomechannel, welcomemessage: pref.WELCOME.welcomemessage }});
await dbo.updateOne({ _id: 'LOG' }, {$set: { keepLogs: pref.LOG.keepLogs, logchannel: pref.LOG.logchannel, severity: pref.LOG.severity }});
await dbo.updateOne({ _id: 'announcement' }, {$set: { channel: pref.announcement.channel, role: pref.announcement.role }});
}).then(() => { res.send("DONE"); })
.catch((err) => {
console.error(err);
+6 -5
View File
@@ -73,9 +73,6 @@
window.onload = async () => {
//#region GUILDS
// const guilds = JSON.parse(JSON.parse(window.localStorage.getItem('guilds')));
//Guilds section
const sessionDataPromise = getSessionData();
sessionDataPromise.then((sessionData) => {
const guilds = JSON.parse(sessionData.guilds);
@@ -120,10 +117,14 @@
imagem.onclick = function() {
var xhr = new XMLHttpRequest();
xhr.open('post', 'http://www.selmerbot.com/getServer/', true);
xhr.open('post', 'http://www.selmerbot.com/setCurrentServer/', true);
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8');
xhr.setRequestHeader('serverNumber', guilds[i].id);
xhr.onloadend = (e) => { window.localStorage.setItem('serverInfo', (xhr.response)); window.location = 'http://www.selmerbot.com/dashboard.html'; }
xhr.setRequestHeader('sessionid', window.localStorage.getItem("sessionId"));
xhr.onloadend = (e) => {
// window.sessionStorage.setItem('serverInfo', (xhr.response));
window.location = 'http://www.selmerbot.com/dashboard.html';
}
xhr.send();
}
} else {
+1 -1
View File
@@ -176,7 +176,7 @@
const offsetTS = offset * 60000;
const d = new Date(new Date().getFullYear(), new Date().getMonth(), day, hour, minute);
const serverSettings = JSON.parse(window.localStorage.getItem('serverInfo'));
const serverSettings = JSON.parse(window.sessionStorage.getItem('serverInfo'));
const sessionDataPromise = getSessionData();
sessionDataPromise.then((sessionData) => {
+5 -3
View File
@@ -163,14 +163,16 @@
}
function logout() {
window.localStorage.clear();
window.sessionStorage.clear();
var xhr = new XMLHttpRequest();
xhr.open('post', 'http://www.selmerbot.com/logout/', true);
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8');
xhr.setRequestHeader('sessionid', window.localStorage.getItem('sessionId'));
xhr.onloadend = (e) => { window.location.href = 'index.html'; }
xhr.onloadend = (e) => {
window.localStorage.clear();
window.sessionStorage.clear();
window.location.href = 'index.html';
}
xhr.send();
}