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.