girlswhocode_allison_cohen

Criando facebook reactions com css

Share This:

<div class="box">
 <input type="checkbox" id="like" class="field-reactions">
 <span class="text-desc">Press space and after tab key to navigation</span>
 <label for="like" class="label-reactions">Like</label>
 <div class="toolbox"></div>
 <label class="overlay" for="like"></label>
 <button class="reaction-like"><span class="legend-reaction">Like</span></button>
 <button class="reaction-love"><span class="legend-reaction">Love</span></button>
 <button class="reaction-haha"><span class="legend-reaction">Haha</span></button>
 <button class="reaction-wow"><span class="legend-reaction">Wow</span></button>
 <button class="reaction-sad"><span class="legend-reaction">Sad</span></button>
 <button class="reaction-angry"><span class="legend-reaction">Angry</span></button>
</div>

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

O CSS
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.

[class*="reaction-"] {
border: none;
background-image: url(https://fbstatic-a.akamaihd.net/rsrc.php/v2/yh/r/sqhTN9lgaYm.png);
background-color: transparent;
display: block;
cursor: pointer;
height: 48px;
position: absolute;
width: 48px;
z-index: 11;
top: -28;
transform-origin: 50% 100%;
transform: scale(0.1);
transition: all 0.3s;
outline: none;
will-change: transform;
opacity: 0;
}

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)

.box:hover .reaction-love {
 transition-delay: 0.03s;
}
.box:hover .reaction-haha {
 transition-delay: 0.09s;
}
.box:hover .reaction-wow {
 transition-delay: 0.12s;
}
.box:hover .reaction-sad {
 transition-delay: 0.15s;
}
.box:hover .reaction-angry {
 transition-delay: 0.18s;
}

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.

.box:hover [class*="reaction-"]:hover .legend-reaction, 
.box:hover [class*="reaction-"]:focus .legend-reaction {
 opacity: 1;
}

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

[class*="reaction-"] {
 transform-origin: 50% 100%;
 transform: scale(0.1);
 transition: all 0.3s;
 will-change: transform, opacity;
}

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 {.codepen}

O resultado por ser conferido aqui

Fonte: Tableless