Criando a funcionalidade do bloco countdown
Criando a funcionalidade do bloco countdown
Introdução
Agora que o básico do nosso componente está funcional, é hora de implementar efetivamente o contador. Para isso, é preciso utilizar um hook do React, chamado useState
;
O hook useState
useState
É chamado dentro de um componente funcional para atualizar e consumir o state de um componente. O state simboliza o estado atual de um componente.
O
useState
retorna um par: o valor do estado atual e uma função para atualizá-lo.
Voltando ao exemplo apresentado na etapa anterior, podemos mostrar na prática os conceitos abordados anteriormente. Para lembrar do exemplo, veja o código abaixo:
const [count, setCount] = useState(0)
No trecho acima é importante observar três coisas:
- Na variável
count
, é possível consumir o estado atual; setCount
é uma função para atualizá-lo;0
é o valor do estado inicial
const [timeRemaining, setTime] = useState<TimeSplit>({
hours: '00',
minutes: '00',
seconds: '00',
})
Fazendo seu contador funcionar!
-
Precisamos importar algumas funções e tipos para continuar:
//react/Countdown.tsx import React, { useState } from 'react' import { TimeSplit } from './typings/global' import { tick, getTwoDaysFromNow } from './utils/time'
A função
getTwoDaysFromNow
será utilizada para tratar condições de borda. Será explicado mais tarde neste passo. -
Adicione o hook de atualização de estado (
useState
)//react/Countdown.tsx const Countdown: StorefrontFunctionComponent<CountdownProps> = ({ targetDate }) => { + const [timeRemaining, setTime] = useState<TimeSplit>({ + hours: '00', + minutes: '00', + seconds: '00' + }) return ( <div> { targetDate } </div> ) }
Observe os detalhes:
timeRemaining
é o estado atual,setTime
é a função de atualização do estado,TimeSplit
é o tipo e, por fim, o objeto{hours: '00', minutes: '00', seconds: '00'}
é o estado inicial do componente. -
Adicione uma
targetDate
padrão para o caso de não haver um valor inicial definido. Vamos utilizar para isto uma data que é definida como dois dias a partir da data atual e ela será calculada em uma função utilitária que foi previamente importada da pasta/utils
://react/Countdown.tsx const DEFAULT_TARGET_DATE = getTwoDaysFromNow()
-
Utilize a função
tick
e a constanteDEFAULT_TARGET_DATE
para fazer o contador://react/Countdown.tsx const Countdown: StorefrontFunctionComponent<CountdownProps> = ({ targetDate = DEFAULT_TARGET_DATE }) => { const [timeRemaining, setTime] = useState<TimeSplit>({ hours: '00', minutes: '00', seconds: '00' }) + tick(targetDate, setTime) return ( <div> { targetDate } </div> ) }
-
Altere o
h1
para que ele exiba o contador que criamos. Para isso, precisamos utilizar o estado atualtimeRemaining
://react/Countdown.tsx const Countdown: StorefrontFunctionComponent<CountdownProps> = ({ targetDate = DEFAULT_TARGET_DATE }) => { const [timeRemaining, setTime] = useState<TimeSplit>({ hours: '00', minutes: '00', seconds: '00' }) tick(targetDate, setTime) return ( <div> - <h1>{ targetDate }</h1> + <h1>{ `${timeRemaining.hours}:${timeRemaining.minutes}:${timeRemaining.seconds}` }</h1> </div> ) }
A formatação da string do contador está no formato
HH:MM:SS
, feita através do split emhours
,minutes
eseconds
.
Assim, com essas alterações, veremos a atualização em tempo real do contador! O resultado na home é esse:
Está com dúvidas?
Veja o gabarito para esta etapa ou acompanhe nosso [office hours] no canal VTEX Developers(https://www.youtube.com/c/VTEXDevelopers)
Ajude-nos a fazer este conteúdo melhor!
Os cursos do VTEX IO são de código aberto. Se você perceber algum problema, pode abrir um pull request!
Faça uma contribuiçãoUpdated 8 months ago