Criando facebook reactions com css

Introdução No dia 24 de fevereiro de 2016, o Facebook liberou seus novos botões de curtir, chamado de “Facebook Reactions”, a função foi liberada para todos os usuários, já que estava em fase de testes em alguns países. São eles: Curtir, Amei, Haha, Uau, Triste, Grr. Essa novidade é uma ótima maneira de saber como

Introdução

No dia 24 de fevereiro de 2016, o Facebook liberou seus novos botões de curtir, chamado de “Facebook Reactions”, a função foi liberada para todos os usuários, já que estava em fase de testes em alguns países.

São eles: Curtir, Amei, Haha, Uau, Triste, Grr.

Essa novidade é uma ótima maneira de saber como seus contatos reagem ao que você compartilha na rede social.

Em 2014 o Facebook registrou a patente que previa esses botões com sentimentos, leia mais detalhes.

Como sou apaixonado por CSS, resolvi criar essas micro interações ao passar o mouse sobre o elemento, e também caso use o teclado.

Cheguei a olhar como o Facebook criou aquelas animações, e resolvi fazer algo mais simples usando a propriedade translate e não animation conforme eles usaram no deles.

Veja o HTML

o HTML

Linha 1: área geral do elemento que recebe o hover  e com isso inicia as interações utilizando o mouse.

Linha 2: input checkbox utilizado pra iniciar as interações ao ser checado via mouse ou teclado.

Linha 3: mensagem exibida pro usuário assim que ele navegar com o teclado e o input da linha 2 receber o foco.

Linha 4: elemento que recebe o background do like e também ao ser clicado faz o change do input checkbox e iniciando as interações.

Linha 5: caixa branca com borda arredondada que tem uma animação diferente dos reactions, por isso ele não é pai dos elementos.

Linha 6: overlay sem cor alguma que serve pra fechar as interações, caso o usuário clique na área fora do box.

Linha 7 a 12: reactions do Facebook que possui uma animação ao receber o :hover ou :focus.  Adicionei em cada um a propriedade transition-delay com diferença de 0.03s entre eles

Para exibir os Reactions através do mouse, utilizei o :hover do CSS na classe .box , que é o pai geral dos elementos.

Para exibir via teclado, ou click do mouse, existe um input[type=”checked”], que manipula seus irmãos (os Reactions e o background branco com borda arredondada).

O elemento branco com borda arredondada, mesmo que visualmente ele esteja atrás como background dos Reactions, no html ele é irmão, com isso foi feito uma outra animação específica pra ele, algo bem simples, apenas dando um show.

Os Reactions

Conforme se vê abaixo, é chamado o sprite dos Reactions e seus elementos de exibição (width, height, position, top, etc). Os reactions inicia com opacidade, 0 scale 10%, e o transform-origin. Lembrando que eles serão exibidos quando o elemento pai (.box) receber o hover do mouse e/ou quando o input for checado.

Animando

Como temos aquele input[type=”checked], citado anteriormente, através do CSS, podemos usar o :hover, e o :checked desse input e gerar nossas interações mais fáceis em seus irmãos, ou seja, manipulado a opacidade e o scale dos Reactions, ao passar o mouse, ou clicar no like, ou navegar com o teclado checando o input escondido.

Se vocês repararem existe uma diferença de animação entre o primeiro Reactions e o último e isso foi resolvido bem simples, aplicando um delay pra cada um. (veja abaixo)

Pra finalizar, existe um outro comportamento aplicado em cada Reactions que exibe a legenda (inicia com opacidade 0), e muda no :hover e o :focus de cada Reaction para 1 na opacidade.

Inicialmemte eles estão escondidos e pequenos e ao passar o mouse ou receber o foco, são exibidos.

Bônus

A propriedade  will-change  otimiza animações, permitindo que o navegador sabe quais propriedades e elementos estão prestes a ser manipulados, aumentando potencialmente o desempenho dessa operação específica.

O will-change é uma recomentação do W3C, desde dezembro de 2015, e seu suporte aos navegadores atuais são bons, segundo o caninuse somente os IEs e o Edge não dão suporte atualmente.

Para saber mais sobre will change veja a documentação do W3C

Em resumo

O grande segredo então seria conhecer algumas propriedades de animação como, translate, transform, opacity, visibility, e lembrar que podemos manipular elementos irmãos com :checked ou :hover do pai e manipular seus elementos filhos.

Veja o demo

See the Pen

wGvbwY

by
Deivid Marques
@deividmarques
on
CodePen.

Conclusão

Inicialmente criei as interações acontecendo apenas no click do elemento, porém no resultado final mudei para o hover do mouse, e também deixei funcionando ao usar a tecla TAB, sendo foi possível navegar pelos “Reactions” com o teclado também.

Utilizei HTML e SASS, claro que daria pra fazer de outras maneiras, escrever menos códigos, até mesmo usando funções do sass em alguns lugares, mas isso ficará pra próxima versão.

O intuito de criar esse pequeno exemplo foi me divertir e também em mostrar os poderes que o CSS têm ao se criar essas micro interações.

Deixe um comentário

O seu endereço de e-mail não será publicado. Campos obrigatórios são marcados com *