Modificando o bloco countdown para ter estilos configuráveis
Introdução
Agora que já implementamos o countdown, que tal adicionar um pouco de customização? Nessa etapa, você irá aprender conceitos básicos a respeito de CSS handles e Tachyons para, em seguida, customizar o estilo da sua app.
CSS Handles
Os handles de CSS são utilizados para customizar os componentes da sua loja através de classes de CSS no código do tema. Todas essas configurações são definidas através da appvtex.css-handles, responsável por declarar todos os pontos de customização do seu bloco.
Definindo os nomes dos seus handles e adicionando aos seus respectivos elementos HTML, é possível entregar ao usuário do tema pontos de customização que que permitam criar layouts flexíveis.
Tachyons
O Tachyons é um framework para CSS funcional. Diferentemente de outros frameworks conhecidos, como o Bootstrap, ele não apresenta componentes UI "pré-buildados". Na verdade, seu objetivo é justamente separar as regras de CSS em partes pequenas e reutilizáveis. Esse tipo de estratégia é comumente conhecida como Subatomic Design System e, caso você tenha interesse, pode encontrar uma referência neste link. Essa estratégia torna frameworks como o Tachyons muito flexíveis, escaláveis e rápidos.
Grande parte das definições de Tachyons podem ser alteradas, de forma que sua loja passe a ter um estilo mais customizado. Para isso, basta definir um arquivo JSON na pasta styles/configs; essas informações podem ser encontradas de forma mais detalhada em: Build a store using VTEX IO - Customizing styles.
Atividade
Importe o hookuseCssHandles. Para isso, volte ao Countdown.tsx e faça o import:
// react/Countdown.tsx
import { useCssHandles } from 'vtex.css-handles'
Além disso, defina em um Array todos os handles que serão necessários (neste caso, será utilizado apenas 'countdown'):
Por fim, é preciso utilizar o handle no componente a fim de ver a customização. Para isso, é necessário utilizar a prop className com as classes a serem utilizadas e as classes de Tachyons, para os estilos globais.
Modificando o bloco countdown para ter estilos configuráveis
Introdução
Agora que já implementamos o
countdown
, que tal adicionar um pouco de customização? Nessa etapa, você irá aprender conceitos básicos a respeito de CSS handles e Tachyons para, em seguida, customizar o estilo da sua app.CSS Handles
Os handles de CSS são utilizados para customizar os componentes da sua loja através de classes de CSS no código do tema. Todas essas configurações são definidas através da app
vtex.css-handles
, responsável por declarar todos os pontos de customização do seu bloco.Definindo os nomes dos seus handles e adicionando aos seus respectivos elementos HTML, é possível entregar ao usuário do tema pontos de customização que que permitam criar layouts flexíveis.
Tachyons
O Tachyons é um framework para CSS funcional. Diferentemente de outros frameworks conhecidos, como o Bootstrap, ele não apresenta componentes UI "pré-buildados". Na verdade, seu objetivo é justamente separar as regras de CSS em partes pequenas e reutilizáveis. Esse tipo de estratégia é comumente conhecida como Subatomic Design System e, caso você tenha interesse, pode encontrar uma referência neste link. Essa estratégia torna frameworks como o Tachyons muito flexíveis, escaláveis e rápidos.
Grande parte das definições de Tachyons podem ser alteradas, de forma que sua loja passe a ter um estilo mais customizado. Para isso, basta definir um arquivo JSON na pasta
styles/configs
; essas informações podem ser encontradas de forma mais detalhada em: Build a store using VTEX IO - Customizing styles.Atividade
Importe o hook
useCssHandles
. Para isso, volte aoCountdown.tsx
e faça o import:Além disso, defina em um Array todos os handles que serão necessários (neste caso, será utilizado apenas
'countdown'
):Utilize o
useCssHandles
no componenteCountdown
para definir o handle docountdown
:Por fim, é preciso utilizar o handle no componente a fim de ver a customização. Para isso, é necessário utilizar a prop
className
com as classes a serem utilizadas e as classes de Tachyons, para os estilos globais.Vamos ver o resultado?