1
0
Fork 0
mirror of https://github.com/GuerillaStudio/compteur-de-greve.git synced 2025-01-04 17:51:57 +00:00

bind real api

This commit is contained in:
wryk 2023-03-02 09:35:56 +01:00
parent f8c0110223
commit ea849aacc6
4 changed files with 16 additions and 34 deletions

View file

@ -18,6 +18,8 @@ module.exports = function (eleventyConfig) {
eleventyConfig.addPassthroughCopy("src/js/**/*.js") eleventyConfig.addPassthroughCopy("src/js/**/*.js")
eleventyConfig.addPassthroughCopy({ "static": "/" }) eleventyConfig.addPassthroughCopy({ "static": "/" })
eleventyConfig.addFilter("formatNumber", number => number.toString().replace(/\B(?=(\d{3})+(?!\d))/g, " "));
return { return {
htmlTemplateEngine: "njk", htmlTemplateEngine: "njk",
dir: { dir: {

View file

@ -1,3 +1,5 @@
module.exports = function() { module.exports = async function() {
return Promise.resolve({count: 69420}) const response = await fetch("https://c.compteurdegreve.fr/val")
const data = await response.json()
return {count: data.value}
} }

View file

@ -13,7 +13,7 @@ permalink:
<span class="color-pink-2 pb05 inline-block">Contre la réforme des retraites,</span><br> <span class="color-pink-2 pb05 inline-block">Contre la réforme des retraites,</span><br>
À lappel de lensemble des organisations syndicales, <span class="color-purple-1">le 7 mars</span> À lappel de lensemble des organisations syndicales, <span class="color-purple-1">le 7 mars</span>
<span aria-live="polite"> <span aria-live="polite">
<strong class="counter-number" x-bind="counter">{{count}}</strong> <strong class="counter-number" x-bind="counter">{{count | formatNumber}}</strong>
<span class="separator">personnes seront</span> <span class="separator">personnes seront</span>
<em class="counter-strikeeeee-lol highlighter-zigzag">en grève<span class="visually-hidden"> !</span></em> <em class="counter-strikeeeee-lol highlighter-zigzag">en grève<span class="visually-hidden"> !</span></em>
</span> </span>

View file

@ -1,5 +1,3 @@
let internalCount = 0
document.addEventListener('alpine:init', () => { document.addEventListener('alpine:init', () => {
Alpine.data('counter', () => ({ Alpine.data('counter', () => ({
count: null, count: null,
@ -57,7 +55,8 @@ document.addEventListener('alpine:init', () => {
this.loading = true this.loading = true
this.errored = false this.errored = false
incrementCount().then(() => { incrementCount().then((newCount) => {
this.count = newCount
this.participating = true this.participating = true
}).catch((error) => { }).catch((error) => {
this.errored = true this.errored = true
@ -105,7 +104,7 @@ function subscribeCount(onCount) {
function execute() { function execute() {
fetchCount().then(newCount => { fetchCount().then(newCount => {
if (!unsubscribed) { if (!unsubscribed) {
timeoutId = setTimeout(execute, 2000) timeoutId = setTimeout(execute, 5000)
onCount(newCount) onCount(newCount)
} }
}) })
@ -122,35 +121,14 @@ function subscribeCount(onCount) {
} }
} }
// fake api
function fetchCount() { function fetchCount() {
return wait(1000).then(() => { return fetch("https://c.compteurdegreve.fr/val")
internalCount += randomInt(0, 9) .then(res => res.json())
return internalCount .then(data => data.value)
})
} }
function incrementCount() { function incrementCount() {
return wait(1000).then(() => { return fetch("https://c.compteurdegreve.fr/incr", { method: "POST", mode: "cors", credentials: "include"})
if (!randomInt(0, 1)) { .then(res => res.json())
throw new Error() .then(data => data.value)
}
internalCount += 1 + randomInt(0, 9)
return internalCount
})
}
function wait(ms) {
return new Promise(res => setTimeout(res, ms))
}
function randomInt(min, max) {
min = Math.ceil(min)
max = Math.floor(max)
return Math.floor(Math.random() * (max - min + 1)) + min
} }