mirror of
https://github.com/GuerillaStudio/compteur-de-greve.git
synced 2025-01-04 17:51:57 +00:00
expose loading and error
This commit is contained in:
parent
d1b105db08
commit
1810883768
2 changed files with 28 additions and 6 deletions
|
@ -9,7 +9,7 @@ title: Compteur de grève
|
|||
<p>
|
||||
<span class="color-3">Contre la réforme des retraites,</span><br>
|
||||
à l’appel de l’ensemble des organisations syndicales, le 7 mars
|
||||
<strong class="block counter text-big text-bold" v-text="count">148 563</strong>
|
||||
<strong class="block counter text-big text-bold" v-text="formattedCount">148 563</strong>
|
||||
<span class="separator">personnes seront</span>
|
||||
<em class="block text-big text-bold">en grève<span class="visually-hidden"> !</span></em>
|
||||
</p>
|
||||
|
@ -20,13 +20,13 @@ title: Compteur de grève
|
|||
<div class="flex flex-col">
|
||||
<div>
|
||||
<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>
|
||||
<div class="success" v-cloak v-if="participating">
|
||||
<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
|
||||
</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>
|
||||
<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>
|
||||
|
|
|
@ -3,7 +3,6 @@ import { createApp } from "https://unpkg.com/petite-vue@0.4.1/dist/petite-vue.es
|
|||
|
||||
let internalCount = 0
|
||||
|
||||
|
||||
createApp({
|
||||
App
|
||||
}).mount(document.body)
|
||||
|
@ -13,12 +12,30 @@ function App({ initialCount }) {
|
|||
|
||||
return {
|
||||
count: initialCount,
|
||||
|
||||
get formattedCount() {
|
||||
return this.count.toString().replace(/\B(?=(\d{3})+(?!\d))/g, " ")
|
||||
},
|
||||
|
||||
participating: false,
|
||||
error: false,
|
||||
loading: false,
|
||||
|
||||
async submit(event) {
|
||||
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,
|
||||
|
@ -71,6 +88,11 @@ async function fetchCount() {
|
|||
|
||||
async function incrementCount() {
|
||||
await wait(1000)
|
||||
|
||||
if (!randomInt(0, 1)) {
|
||||
throw new Error()
|
||||
}
|
||||
|
||||
internalCount += 1 + randomInt(0, 9)
|
||||
return internalCount
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue