458 lines
15 KiB
HTML
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…</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>
|