/* Set the width of the side navigation to 250px and the left margin of the page content to 250px and add a black background color to body */
function openNav() {
document.getElementById("mySidenav").style.width = "250px";
document.getElementById("main").style.marginLeft = "250px";
document.body.style.backgroundColor = "rgba(0,0,0,0.4)";
}
/* Set the width of the side navigation to 0 and the left margin of the page content to 0, and the background color of body to white */
function closeNav() {
document.getElementById("mySidenav").style.width = "0";
document.getElementById("main").style.marginLeft = "0";
document.body.style.backgroundColor = "white";
}
window.onload = function() {
document.getElementById('sideload').style.display = 'block';
var config = {
apiKey: "(insert the TitanScout Api Key Here)",
authDomain: "titanscoutandroid.firebaseapp.com",
databaseURL: "https://titanscoutandroid.firebaseio.com",
projectId: "titanscoutandroid",
storageBucket: "titanscoutandroid.appspot.com",
messagingSenderId: "1097635313476"
};
//eventually find a less-jank way to do this tho
firebase.initializeApp(config);
firebase.auth().onAuthStateChanged(function(user) {
if (user != null) {
if (user.displayName != null) {
document.getElementById('status').innerHTML = "You are signed in as: " + user.displayName;
} else if (user.email != null) {
document.getElementById('status').innerHTML = "You are signed in as: " + user.email;
} else if (user.phoneNumber != null) {
document.getElementById('status').innerHTML = "You are signed in as: " + user.phoneNumber;
} else {
document.getElementById('status').innerHTML = "You are signed in.";
}
} else {
window.location.replace('../../');
}
teamAssoc = firebase.firestore().collection('UserAssociations').doc(user.uid);
teamAssoc.get().then(function(doc) {
if (doc.exists) {
list = doc.data()
teamNums = Object.keys(list)
document.getElementById('tns').innerHTML = ""
for (var i = 0; i < teamNums.length; i++) {
document.getElementById('tns').innerHTML += ""
}
} else {}
}).then(function() {
changeTeam(document.getElementById('tns').value)
})
});
}
function changeTeam(teamNum) {
//remove all event listeners for element by cloning it
var old_element = document.getElementById("mSelect");
var new_element = old_element.cloneNode(true);
old_element.parentNode.replaceChild(new_element, old_element);
//ok back to normal stuff
var user = firebase.auth().currentUser;
ti = firebase.firestore().collection('teamData').doc("team-" + teamNum);
currentComp = null;
ti.get().then(function(doc) {
if (doc.exists) {
info = doc.data();
currentComp = info['currentCompetition'];
} else {
alert("Something's wrong with firebase.");
throw ("Something's wrong with firebase.");
}
}).then(function() {
if (currentComp != null) {
comps = firebase.firestore().collection('matchSignupsIndividual').doc(user.uid).collection("team-" + teamNum).doc(currentComp);
comps.get().then(function(doc) {
if (doc.exists) {
var matches = doc.data();
document.getElementById('mSelect').innerHTML = "";
for (var i = 0; i < Object.keys(matches).length; i++) {
name = Object.keys(matches)[i];
series = matches[Object.keys(matches)[i]]['series'];
completed = matches[Object.keys(matches)[i]]['completed'];
if (!completed) {
document.getElementById('mSelect').innerHTML += ""
}
}
document.getElementById('mSelect').addEventListener("change", function() {
updateForm(document.getElementById('mSelect').value, teamNum, currentComp);
});
}
});
}
});
}
function lastWord(words) {
var n = words.split(" ");
return n[n.length - 1];
}
function firstWord(words) {
var n = words.split(" ");
return n[0];
}
function updateForm(locString, teamNum, competition) {
seriesList = [];
document.getElementById('FormData').innerHTML = ""
loc = firebase.firestore().collection('appBuliding').document("team-" + teamNum).collection('competitions').document(competition).collection(lastWord(locString));
loc.get().then(function(docs) {
docs.forEach(function(doc) {
seriesList.push(doc.data());
});
seriesList.sort(function(a, b) {
return a.order - b.order;
})
for (var i = 0; i < seriesList.length; i++) {
document.getElementById('FormData').innerHTML += "
"
seriesList[i].id + "
";
labels = Object.keys(seriesList[i].data());
var index = labels.indexOf('order');
if (index > -1) {
labels.splice(index, 1);
}
var questions = [];
for (var j = 0; j < labels.length; j++) {
questions.push([labels[j], seriesList[i].data()[labels[j]]])
}
questions.sort(function(a, b) {
return a[1].order - b[1].order;
})
for (var j = 0; j < questions.length; j++) {
document.getElementById('FormData').innerHTML += "
"
for (var k = 0; k < questions[j][1]['elements'].length; k++) {
//// TODO: replace with real buttons for good styling
document.getElementById('FormData').innerHTML += questions[j][1]['elements'][k];
document.getElementById('FormData').innerHTML += ""
}
document.getElementById('FormData').innerHTML += "