Chakra UI é o melhor amigo do desenvolvedor da web. Uma biblioteca baseada em componentes formada por blocos de construção básicos que você pode usar para construir aplicativos da web, Chakra UI ajuda a “construir aplicativos React acessíveis com velocidade”.
Os componentes da IU do Chakra são acessíveis e compatíveis com WAI-ARIA, e sua API torna componentes de personalização e temas fácil. Mas isso nem arranha a superfície dos benefícios que oferece aos desenvolvedores.
Nosso foco neste artigo é examinar algumas das coisas legais que podemos fazer com a IU do Chakra que vão além do básico, e como eles podem aumentar nossa produtividade como desenvolvedores. Eu preparei uma demonstração das coisas que veremos. Aqui estão os links para a artigo de demonstração e o repositório GitHub se desejar acompanhar.
Este artigo foi escrito com Next.js. As implementações da IU do Chakra são semelhantes em todo o ecossistema React, no entanto, haverá algumas diferenças quando se trata de conceitos como roteamento, que apontarei quando chegarmos a eles no tutorial.
Criação dinâmica SVGs
Ao criar diferentes temas para o seu site, você pode querer alterar dinamicamente os SVGs para se ajustarem ao tema atual. Isso significa criar versões diferentes de cada SVG para cada tema.
Embora isso tecnicamente funcione, a IU do Chakra fornece um método mais limpo. Podemos usar o gancho useColorMode da IU do Chakra para alterar programaticamente o preenchimento de nossos SVGs e torná-los dinâmicos.
Antes de usarmos useColorMode, precisamos implementar o modo escuro. Este guia pode ajudar se você não usou o modo escuro com Chakra UI já.
Uma vez que o modo escuro foi configurado, podemos usar useColorMode:
No trecho de código acima, importamos o gancho useColorMode e os SVGs que queremos tornar dinâmicos. Podemos acessar colorMode e toggleColorMode em useColorMode. colorMode é o modo de cor atual e toggleColorMode é a função para alternar o modo de cor.
Passamos a função toggleColorMode para o manipulador de eventos onClick do botão e colorMode para os componentes SVG:
function lightBulb ( {colorMode}) {return (
Para estender ou substituir um token no tema padrão, importamos a função extendTheme e adicionamos as teclas que deseja substituir. Vamos ver como estender o objeto do tema.
Para começar, criamos um arquivo Theme.js e, em seguida, criamos as definições de estilo para nosso aplicativo lá:
Estendemos as cores adicionando duas novas (as cores da nossa marca) no objeto do tema. Também podemos definir tokens de estilo para fontes, pontos de interrupção, tamanhos de fonte, alturas de linha e muito mais, dependendo dos requisitos de design do aplicativo.
Para usar este novo objeto de tema com os estilos estendidos adicionados, vamos para o raiz de nosso aplicativo, onde configuramos ChakraProvider:
import {ChakraProvider} de”@ chakra-ui/react”; importar tema de”tema”; importar Nav de”Nav”; function MyApp ({Component, pageProps, router}) {return (
Reconhecidamente, este será um começo lento, mas o Google está lançando dois planos de fundo virtuais incrivelmente legais para o Google Meet no Android e no iOS que permitem aos usuários não apenas alterar seus Read more…
De acordo com o estudo mais recente conduzido pela Chainalysis, usuários involuntários gastaram cerca de US$ 4,6 bilhões em criptomoedas, adquirindo-as em esquemas fraudulentos no ano passado, que resultaram na criação de mais de 1,1 Read more…
O principal mercado de NFT, OpenSea, fez alguns anúncios importantes nas últimas horas. Por meio de sua conta oficial no Twitter, a OpenSea listou várias alterações em sua estrutura de taxas e royalties, que devem Read more…