mirror of
https://github.com/aquatix/alfagok.git
synced 2025-12-07 00:25:12 +01:00
Compare commits
8 Commits
8eb0f5728d
...
4bacc75a42
| Author | SHA1 | Date | |
|---|---|---|---|
| 4bacc75a42 | |||
| 948267359a | |||
| b942200833 | |||
| 370ce60b32 | |||
| 6ff55f4878 | |||
| 898362db72 | |||
| a7499d4e74 | |||
| 43dbf54e53 |
@@ -89,7 +89,7 @@ Environment="DICTIONARY_LIST=/srv/www_data/alfagok.example.com/dictionary.txt"
|
|||||||
Environment="STATIC_DIR=/srv/www/alfagok.example.com/alfagok/src/alfagok/static"
|
Environment="STATIC_DIR=/srv/www/alfagok.example.com/alfagok/src/alfagok/static"
|
||||||
Environment="TEMPLATE_DIR=/srv/www/alfagok.example.com/alfagok/src/alfagok/templates"
|
Environment="TEMPLATE_DIR=/srv/www/alfagok.example.com/alfagok/src/alfagok/templates"
|
||||||
|
|
||||||
ExecStart=/srv/www/alfagok.example.com/venv/bin/gunicorn -c /srv/www/_webconfig/sites/alfagok.diginaut.net/gunicorn_alfagok_conf.py alfagok.main:app
|
ExecStart=/srv/www/alfagok.example.com/venv/bin/gunicorn -c /srv/www/_webconfig/sites/alfagok.example.com/gunicorn_alfagok_conf.py alfagok.main:app
|
||||||
|
|
||||||
[Install]
|
[Install]
|
||||||
WantedBy=multi-user.target
|
WantedBy=multi-user.target
|
||||||
|
|||||||
@@ -7,6 +7,8 @@ body {
|
|||||||
padding: 2rem 1rem;
|
padding: 2rem 1rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[x-cloak] { display: none !important; }
|
||||||
|
|
||||||
a.title {
|
a.title {
|
||||||
color: #FF9800;
|
color: #FF9800;
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
@@ -23,12 +25,16 @@ a.title {
|
|||||||
float: right;
|
float: right;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#container center {
|
||||||
|
padding-top: 2rem;
|
||||||
|
}
|
||||||
|
|
||||||
.instructions {
|
.instructions {
|
||||||
padding: 2rem 0 0 0;
|
padding: 2rem 0 0 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.guessesbefore {
|
.guessesheading {
|
||||||
padding-top: 2rem;
|
color: #CCC;;
|
||||||
}
|
}
|
||||||
|
|
||||||
input[type="text"] {
|
input[type="text"] {
|
||||||
@@ -61,3 +67,12 @@ input[type="text"], button, .error {
|
|||||||
padding: .5rem;
|
padding: .5rem;
|
||||||
font-size: 1.5rem;
|
font-size: 1.5rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.win {
|
||||||
|
background-color: rgb(42 73 54);
|
||||||
|
padding: 1rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
.results {
|
||||||
|
background-color: #333;
|
||||||
|
}
|
||||||
|
|||||||
@@ -16,6 +16,10 @@ document.addEventListener('alpine:init', () => {
|
|||||||
|
|
||||||
guessError: '',
|
guessError: '',
|
||||||
|
|
||||||
|
resultGameID: '',
|
||||||
|
resultGuesses: '',
|
||||||
|
resultTimeTaken: '',
|
||||||
|
|
||||||
async getGameID() {
|
async getGameID() {
|
||||||
/* Get the game number from the backend */
|
/* Get the game number from the backend */
|
||||||
this.loading = true;
|
this.loading = true;
|
||||||
@@ -30,7 +34,6 @@ document.addEventListener('alpine:init', () => {
|
|||||||
},
|
},
|
||||||
|
|
||||||
async doGuess() {
|
async doGuess() {
|
||||||
/* Check guess against server */
|
|
||||||
this.guessError = null;
|
this.guessError = null;
|
||||||
|
|
||||||
this.guessValue = this.guessValue.toLowerCase();
|
this.guessValue = this.guessValue.toLowerCase();
|
||||||
@@ -46,11 +49,12 @@ document.addEventListener('alpine:init', () => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
this.nrGuesses++;
|
this.nrGuesses++;
|
||||||
if (this.startTime === '') {
|
if (this.startTime === null) {
|
||||||
console.log('Setting startTime to now');
|
console.log('Setting startTime to now');
|
||||||
this.startTime = now();
|
this.startTime = new Date();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Check guess against server */
|
||||||
this.loading = true;
|
this.loading = true;
|
||||||
|
|
||||||
let response = await fetch('/api/guess/' + this.guessValue);
|
let response = await fetch('/api/guess/' + this.guessValue);
|
||||||
@@ -69,14 +73,19 @@ document.addEventListener('alpine:init', () => {
|
|||||||
if (result.hint && result.hint === 'after') {
|
if (result.hint && result.hint === 'after') {
|
||||||
this.guessesBefore.push(this.guessValue);
|
this.guessesBefore.push(this.guessValue);
|
||||||
this.guessesBefore.sort();
|
this.guessesBefore.sort();
|
||||||
|
this.guessValue = '';
|
||||||
}
|
}
|
||||||
if (result.hint && result.hint === 'before') {
|
if (result.hint && result.hint === 'before') {
|
||||||
this.guessesAfter.push(this.guessValue);
|
this.guessesAfter.push(this.guessValue);
|
||||||
this.guessesAfter.sort();
|
this.guessesAfter.sort();
|
||||||
|
this.guessValue = '';
|
||||||
}
|
}
|
||||||
if (result.hint && result.hint === 'it') {
|
if (result.hint && result.hint === 'it') {
|
||||||
console.log('gevonden!');
|
console.log('gevonden!');
|
||||||
this.winTime = now();
|
this.winTime = new Date();
|
||||||
|
this.resultGameID = '🧩 Puzzel #' + this.gameID;
|
||||||
|
this.resultGuesses = '🤔 '+ this.nrGuesses + ' gokken';
|
||||||
|
this.resultTimeTaken = '⏱️ ' + getFormattedTime(this.winTime - this.startTime);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}),
|
}),
|
||||||
@@ -111,7 +120,7 @@ function getFormattedTime(milliseconds) {
|
|||||||
|
|
||||||
const formattedTime = [];
|
const formattedTime = [];
|
||||||
if (hours) {
|
if (hours) {
|
||||||
formattedTime.push(`${hours}h`);
|
formattedTime.push(`${hours}u`);
|
||||||
}
|
}
|
||||||
if (minutes) {
|
if (minutes) {
|
||||||
formattedTime.push(`${minutes}m`);
|
formattedTime.push(`${minutes}m`);
|
||||||
|
|||||||
@@ -20,42 +20,44 @@
|
|||||||
|
|
||||||
<center>
|
<center>
|
||||||
|
|
||||||
|
<p class="guessesheading" x-cloak x-show="$store.alfagok.guessesBefore.length">Het woord van de dag komt <em>na</em>:</p>
|
||||||
<ul class="guessesbefore">
|
<ul class="guessesbefore">
|
||||||
<template x-for="item in $store.alfagok.guessesBefore" :key="item">
|
<template x-for="item in $store.alfagok.guessesBefore" :key="item">
|
||||||
<li x-text="item"></li>
|
<li x-text="item"></li>
|
||||||
</template>
|
</template>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<input type="text" autocomplete="new-password" autocorrect="off" x-model="$store.alfagok.guessValue" @keyup.enter="$store.alfagok.doGuess()">
|
<div x-show="!$store.alfagok.winTime">
|
||||||
|
<input type="text" autocomplete="new-password" autocorrect="off" x-model="$store.alfagok.guessValue" @keyup.enter="$store.alfagok.doGuess()">
|
||||||
{# <p x-cloak>Je huidige gok is: <span x-text="$store.alfagok.guessValue"></span></p>#}
|
{# <p x-cloak>Je huidige gok is: <span x-text="$store.alfagok.guessValue"></span></p>#}
|
||||||
<button @click="$store.alfagok.doGuess()">Doe een gok</button>
|
<button @click="$store.alfagok.doGuess()">Doe een gok</button>
|
||||||
<p class="error" x-show="$store.alfagok.guessError" x-text="$store.alfagok.guessError"></p>
|
<p class="error" x-cloak x-show="$store.alfagok.guessError" x-text="$store.alfagok.guessError"></p>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div x-cloak x-show="$store.alfagok.winTime" class="win">
|
||||||
|
<h3><b>Je hebt hem! 🎉</b></h3>
|
||||||
|
<p>Het woord van vandaag was <b x-text="$store.alfagok.guessValue"></b>.</p>
|
||||||
|
<div id="stats">
|
||||||
|
<div id="results">
|
||||||
|
<p><b x-text="$store.alfagok.resultGameID"></b></p>
|
||||||
|
<p x-text="$store.alfagok.resultGuesses"></p>
|
||||||
|
<p x-text="$store.alfagok.resultTimeTaken"></p>
|
||||||
|
<p>🔗 <span style="color:var(--blue)">alfagok.diginaut.net</span></p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div id="copyresults"></div>
|
||||||
|
<button class="copy" data-clipboard-target="#results">
|
||||||
|
Tik om te kopiëren en te delen ❤️
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<p class="guessesheading" x-cloak x-show="$store.alfagok.guessesAfter.length">Het woord van de dag komt <em>voor</em>:</p>
|
||||||
<ul class="guessesafter">
|
<ul class="guessesafter">
|
||||||
<template x-for="item in $store.alfagok.guessesAfter" :key="item">
|
<template x-for="item in $store.alfagok.guessesAfter" :key="item">
|
||||||
<li x-text="item"></li>
|
<li x-text="item"></li>
|
||||||
</template>
|
</template>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
<div>
|
|
||||||
<div x-show="$store.alfagok.winTime" class="win">
|
|
||||||
<h3><b>Je hebt hem! 🎉</b></h3>
|
|
||||||
<p>Het woord van vandaag was <b x-text="$store.alfagok.guessValue"></b>.</p>
|
|
||||||
<div id="stats">
|
|
||||||
<div id="results">
|
|
||||||
<p><b x-data="{ message: '🧩 Puzzel #' + $store.alfagok.gameID }" x-text="message"></b></p>
|
|
||||||
<p x-data="{ message: '🤔 '+ $store.alfagok.nrGuesses + ' gokken' }" x-text="message"></p>
|
|
||||||
<p x-data="{ message: '⏱️ ' + getFormattedTime($store.alfagok.winTime - $store.alfagok.startTime) }" x-text="message"></p>
|
|
||||||
<p>🔗 <span style="color:var(--blue)">alfagok.diginaut.net</span></p>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div id="copyresults"></div>
|
|
||||||
<button class="copy" data-clipboard-target="#results">
|
|
||||||
Tik om te kopiëren en te delen ❤️
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</center>
|
</center>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
Reference in New Issue
Block a user