458 lines
15 KiB
HTML

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>Welcome to Firebase Hosting</title>
<!-- update the version number as needed -->
<script defer src="/__/firebase/9.12.1/firebase-app-compat.js"></script>
<!-- include only the Firebase features as you need -->
<script defer src="/__/firebase/9.12.1/firebase-auth-compat.js"></script>
<script defer src="/__/firebase/9.12.1/firebase-database-compat.js"></script>
<script defer src="/__/firebase/9.12.1/firebase-firestore-compat.js"></script>
<script defer src="/__/firebase/9.12.1/firebase-functions-compat.js"></script>
<script defer src="/__/firebase/9.12.1/firebase-messaging-compat.js"></script>
<script defer src="/__/firebase/9.12.1/firebase-storage-compat.js"></script>
<script defer src="/__/firebase/9.12.1/firebase-analytics-compat.js"></script>
<script defer src="/__/firebase/9.12.1/firebase-remote-config-compat.js"></script>
<script defer src="/__/firebase/9.12.1/firebase-performance-compat.js"></script>
<!--
initialize the SDK after all desired features are loaded, set useEmulator to false
to avoid connecting the SDK to running emulators.
-->
<script defer src="/__/firebase/init.js?useEmulator=true"></script>
<style media="screen">
:root {
--ruleColor: #999;
--titleColor: #333;
--textColor: #444;
--infoColor: #666;
--vote1: #444;
--vote2: #888;
--vote3: #ccc;
--vote4: #eee;
}
body { background: #ECEFF1; color: rgba(0,0,0,0.87); font-family: Roboto, Helvetica, Arial, sans-serif; margin: 0; padding: 0; }
#message { background: white; max-width: 360px; margin: 100px auto 16px; padding: 32px 24px; border-radius: 3px; }
#message h2 { color: #ffa100; font-weight: bold; font-size: 16px; margin: 0 0 8px; }
#message h1 { font-size: 22px; font-weight: 300; color: rgba(0,0,0,0.6); margin: 0 0 16px;}
#message p { line-height: 140%; margin: 16px 0 24px; font-size: 14px; }
#message a { display: block; text-align: center; background: #039be5; text-transform: uppercase; text-decoration: none; color: white; padding: 16px; border-radius: 4px; }
#message, #message a { box-shadow: 0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24); }
#load { color: rgba(0,0,0,0.4); text-align: center; font-size: 13px; }
@media (max-width: 600px) {
body, #message { margin-top: 0; background: white; box-shadow: none; }
body { border-top: 16px solid #ffa100; }
}
h1, h2, h3, h4 {
color: var(--titleColor);
}
#prompt {
position: fixed;
bottom: 0;
left: 0;
right: 0;
padding: 8px 16px;
text-align: center;
font-size: 14px;
z-index: 100;
height: 35%;
display: flex;
flex-direction: row;
background-color: #ffffff;
/* margin-bottom: 5%; */ /* TODO: Remove */
/*
background: #039be5;
color: white;
*/
}
/* Twitch chat */
#chat {
display: flex;
width: 20%;
margin: 8px;
flex-direction: column;
/* background: #ffa100; */
}
#chattitle {
align-self: center;
margin-bottom: 1px;
margin-top: 10px;
}
#chatcontent {
display: flex;
flex-direction: column;
flex: 1;
padding: 8px 16px;
list-style: none;
align-items: flex-start;
margin-top: 1px;
-ms-overflow-style: none; /* IE and Edge */
scrollbar-width: none; /* Firefox */
}
#chatcontent::--webkit-scrollbar {
display: none;
visibility: hidden;
}
hr.solid {
border-top: 3px solid var(--ruleColor);
border-radius: 5px;
margin-left: 5px;
margin-right: 5px;
}
/* Main vote info section */
#voteinfo {
display: flex;
width: 80%;
flex-direction: column;
align-items: flex-start;
padding: 8px 16px;
margin: 8px;
/* background: #123123; */
}
#novote {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
flex: 1;
width: 80%;
padding: 8px 16px;
margin: 8px;
}
#voteprompt {
margin-bottom: 1px;
margin-top: 2px;
}
#votes {
list-style: none;
display: flex;
flex-direction: row;
align-items: center;
padding: 0px;
width: 100%;
height: 35px;
margin: 5px 0px;
overflow: hidden;
/* background-color: #ffa100; */
}
#voteextrainfo {
height: 100%;
align-self: stretch;
margin: 0px;
display: flex;
flex-direction: row;
justify-content: space-evenly;
align-items: stretch;
align-content: stretch;
}
#votedetails {
display: flex;
flex-direction: column;
width: 80%;
margin-right: 8px;
/* background-color: #ffa100; */
}
#votehelp {
display: flex;
flex-direction: column;
align-items: flex-start;
margin-left: 8px;
width: 20%;
/* background-color: #ffa100; */
}
.posttitle {
align-self: flex-start;
margin-bottom: 1px;
margin-top: 5px;
}
#postdescription {
font-size: 16px;
text-align: start;
color: var(--textColor);
}
#tipbox {
display: flex;
flex-direction: row;
align-items: baseline;
margin-top: auto;
justify-content: flex-start;
width: 100%;
}
.verticalrule {
border: 1px solid var(--ruleColor);
width: 0px;
height: auto;
outline: none;
}
#optsandinfo {
display: flex;
flex-direction: column;
justify-content: space-evenly;
margin-top: auto;
width: 100%;
}
#votes > li {
padding: 8px 0px;
}
#voteopts {
flex-wrap: wrap;
display: flex;
list-style: none;
align-items: stretch;
justify-content: space-evenly;
padding: 0px;
}
#voteopts > li {
flex: 1 0 35%;
display: flex;
align-items: center;
justify-content: center;
margin: 1%;
border-color: black;
border-style: solid;
border-width: 2px;
}
#voteopts > li > strong {
width: auto;
margin: 5px 0px;
padding: 2px 0px;
color: var(--titleColor);
}
/* General styles */
.outlinebox {
outline-color: black;
outline-style: solid;
outline-width: 2px;
}
.hidden {
display: none !important;
}
</style>
</head>
<body>
<!--
<div id="message">
<h2>Welcome</h2>
<h1>Firebase Hosting Setup Complete</h1>
<p>You're seeing this because you've successfully setup Firebase Hosting. Now it's time to go build something extraordinary!</p>
<a target="_blank" href="https://firebase.google.com/docs/hosting/">Open Hosting Documentation</a>
</div>
<p id="load">Firebase SDK Loading&hellip;</p>
-->
<div id="prompt" class="outlinebox">
<div id="chat" class="outlinebox">
<h2 id="chattitle">JURY NOTES</h2>
<hr class="solid">
<ul id="chatcontent">
<li>asdfasdfasdf</li>
<li>asdf234234</li>
<li>rhg 465y 4</li>
<li>5u 5j </li>
</ul>
</div>
<div id="voteinfo" class="outlinebox">
<h1 id="voteprompt">Is OP the asshole?</h1>
<ul id="votes" class="outlinebox">
<!--<li style="width: 60%; background-color: var(--vote1);">/Yes (60%)</li>
<li style="width: 40%; background-color: var(--vote4);">/No (40%)</li>-->
</ul>
<div id="voteextrainfo">
<div id="votedetails">
<h2 class="posttitle">Post title</h2>
<p id="postdescription">My friends and I want to watch movies that our traumatized friend may find triggering - Would I be the asshole to just not invite her anymore?</p>
<div id="tipbox">
<h3 style="padding-right: 5px; margin-bottom: 0px;">TIP:</h3>
<p style="margin-bottom: 0px;">Get transcript link with the /source command in chat!</p>
</div>
</div>
<hr class="verticalrule">
<div id="votehelp">
<h3 class="posttitle">VOTE NOW!</h3>
<p style="text-align: start; color: var(--infoColor);">Vote by typing one of the following options in chat.</p>
<div id="optsandinfo">
<ul id="voteopts">
<!--
<li><strong>/Yes</strong></li>
<li><strong>/No</strong></li>
-->
</ul>
<p style="margin: 0px; align-self: center; color: var(--infoColor);">23 votes registered</p>
</div>
</div>
</div>
</div>
<div id="novote" class="outlinebox hidden">
<h1>There is currently no vote going on!</h1>
</div>
</div>
<script>
const voteUpdateInterval = 1000;
document.addEventListener('DOMContentLoaded', function() {
//const loadEl = document.querySelector('#load');
// // 🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥
// // The Firebase SDK is initialized and available here!
//
// firebase.auth().onAuthStateChanged(user => { });
// firebase.database().ref('/path/to/ref').on('value', snapshot => { });
// firebase.firestore().doc('/foo/bar').get().then(() => { });
// firebase.functions().httpsCallable('yourFunction')().then(() => { });
// firebase.messaging().requestPermission().then(() => { });
// firebase.storage().ref('/path/to/ref').getDownloadURL().then(() => { });
// firebase.analytics(); // call to activate
// firebase.analytics().logEvent('tutorial_completed');
// firebase.performance(); // call to activate
//
// // 🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥🔥
let activeVoteData = undefined;
function updateVoteUI(fullRefresh) {
if (activeVoteData === undefined) {
document.getElementById("voteinfo").classList.add("hidden");
document.getElementById("novote").classList.remove("hidden");
return;
}
document.getElementById("novote").classList.add("hidden");
document.getElementById("voteinfo").classList.remove("hidden");
if (fullRefresh) {
document.getElementById("voteprompt").innerText = activeVoteData.prompt;
document.getElementById("postdescription").innerText = activeVoteData.description;
}
let totalVotes = 0;
for (let i = 0; i < activeVoteData.votes.length; i++) {
totalVotes += activeVoteData.votes[i];
}
const voteOpts = document.getElementById("voteopts");
const votes = document.getElementById("votes");
if (fullRefresh) {
// Remove all existing vote options
while (voteOpts.firstChild) {
voteOpts.removeChild(voteOpts.firstChild);
}
for (let i = 0; i < activeVoteData.options.length; i++) {
const newOpt = document.createElement("li");
const newOptText = document.createElement("strong");
newOptText.innerText = activeVoteData.options[i];
newOpt.appendChild(newOptText);
voteOpts.appendChild(newOpt);
}
while (votes.firstChild) {
votes.removeChild(votes.firstChild);
}
for (let i = 0; i < activeVoteData.options.length; i++) {
const newVote = document.createElement("li");
newVote.style.width = totalVotes == 0 ? `${100/activeVoteData.options.length}%` : `${(activeVoteData.votes[i] / totalVotes * 100)}%`;
newVote.style.backgroundColor = `var(--vote${i + 1})`;
newVote.innerHTML = activeVoteData.options[i] + " (" + (totalVotes == 0 ? `${+(100/activeVoteData.options.length).toFixed(2)}` : +(activeVoteData.votes[i] / totalVotes * 100).toFixed(2)) + "%)";
votes.appendChild(newVote);
}
} else {
const voteOptsChildren = voteOpts.children;
for (let i = 0; i < voteOptsChildren.length; i++) {
const voteOpt = voteOptsChildren[i];
const voteOptText = voteOpt.children[0];
voteOptText.innerText = activeVoteData.options[i];
}
// Update votes list
const votesChildren = votes.children;
for (let i = 0; i < votesChildren.length; i++) {
const vote = votesChildren[i];
vote.innerHTML = activeVoteData.options[i] + " (" + (totalVotes == 0 ? `${+(100/activeVoteData.options.length).toFixed(2)}` : +(activeVoteData.votes[i] / totalVotes * 100).toFixed(2)) + "%)";
vote.style.width = totalVotes == 0 ? `${100/activeVoteData.options.length}%` : (activeVoteData.votes[i] / totalVotes * 100) + "%";
}
}
document.getElementById("optsandinfo").children[1].innerText = totalVotes + " votes registered";
}
const activeVote = firebase.functions().httpsCallable('activeVote');
function updateVote() {
activeVote().then((data) => {
if (data && data.data) {
console.log(activeVoteData, data);
if (!activeVoteData || activeVoteData.voteId !== data.data.voteId) {
activeVoteData = data.data;
console.log("Full update");
updateVoteUI(true);
} else {
activeVoteData = data.data;
console.log("Partial update");
updateVoteUI(false);
}
}
});
}
updateVoteUI(true);
updateVote();
firebase.firestore().collection('state').onSnapshot(updateVote);
try {
let app = firebase.app();
/*
let features = [
'auth',
'database',
'firestore',
'functions',
'messaging',
'storage',
'analytics',
'remoteConfig',
'performance',
].filter(feature => typeof app[feature] === 'function');
loadEl.textContent = `Firebase SDK loaded with ${features.join(', ')}`;
*/
} catch (e) {
console.error(e);
//loadEl.textContent = 'Error loading the Firebase SDK, check the console.';
}
});
</script>
</body>
</html>