1
0
Fork 0
mirror of https://github.com/GuerillaStudio/compteur-de-greve.git synced 2024-12-18 05:41:56 +00:00

expose loading and error

This commit is contained in:
wryk 2023-03-02 01:47:27 +01:00
parent d1b105db08
commit 1810883768
2 changed files with 28 additions and 6 deletions

View file

@ -9,7 +9,7 @@ title: Compteur de grève
<p> <p>
<span class="color-3">Contre la réforme des retraites,</span><br> <span class="color-3">Contre la réforme des retraites,</span><br>
à lappel de lensemble des organisations syndicales, le 7 mars à lappel de lensemble des organisations syndicales, le 7 mars
<strong class="block counter text-big text-bold" v-text="count">148&nbsp;563</strong> <strong class="block counter text-big text-bold" v-text="formattedCount">148&nbsp;563</strong>
<span class="separator">personnes seront</span> <span class="separator">personnes seront</span>
<em class="block text-big text-bold">en grève<span class="visually-hidden"> !</span></em> <em class="block text-big text-bold">en grève<span class="visually-hidden"> !</span></em>
</p> </p>
@ -20,13 +20,13 @@ title: Compteur de grève
<div class="flex flex-col"> <div class="flex flex-col">
<div> <div>
<form action="/" method="post" v-if="!participating" @submit="submit"> <form action="/" method="post" v-if="!participating" @submit="submit">
<button class="btn w100 mb15">Je fais grève</button> <button class="btn w100 mb15" v-bind:disabled="loading">Je fais grève</button>
</form> </form>
<div class="success" v-cloak v-if="participating"> <div class="success" v-cloak v-if="participating">
<strong class="block text-bold">Merci pour votre participation ! ✨</strong> <strong class="block text-bold">Merci pour votre participation ! ✨</strong>
↓ Nous avons <strong>besoin de vous</strong> pour faire du <em class="text-bold">7 mars</em> une journée de mobilisation qui restera dans les mémoires ↓ Nous avons <strong>besoin de vous</strong> pour faire du <em class="text-bold">7 mars</em> une journée de mobilisation qui restera dans les mémoires
</div> </div>
<div class="error" v-cloak>Message d'erreur à faire</div> <div class="error" v-cloak v-if="error">Message d'erreur à faire</div>
</div> </div>
<a href="#" class="btn btn--secondary w100 mb15">Je partage le compteur</a> <a href="#" class="btn btn--secondary w100 mb15">Je partage le compteur</a>
<a href="#" class="btn btn--ghost w100 mb15">En savoir plus</a> <a href="#" class="btn btn--ghost w100 mb15">En savoir plus</a>

View file

@ -3,7 +3,6 @@ import { createApp } from "https://unpkg.com/petite-vue@0.4.1/dist/petite-vue.es
let internalCount = 0 let internalCount = 0
createApp({ createApp({
App App
}).mount(document.body) }).mount(document.body)
@ -13,12 +12,30 @@ function App({ initialCount }) {
return { return {
count: initialCount, count: initialCount,
get formattedCount() {
return this.count.toString().replace(/\B(?=(\d{3})+(?!\d))/g, " ")
},
participating: false, participating: false,
error: false,
loading: false,
async submit(event) { async submit(event) {
event.preventDefault() event.preventDefault()
this.count = await incrementCount()
this.participating = true try {
this.loading = true
this.error = false
this.count = await incrementCount()
this.participating = true
} catch (error) {
this.error = true
console.log(error)
} finally {
this.loading = false
}
}, },
unsubscribeCount: null, unsubscribeCount: null,
@ -71,6 +88,11 @@ async function fetchCount() {
async function incrementCount() { async function incrementCount() {
await wait(1000) await wait(1000)
if (!randomInt(0, 1)) {
throw new Error()
}
internalCount += 1 + randomInt(0, 9) internalCount += 1 + randomInt(0, 9)
return internalCount return internalCount
} }