Dia 69/2019 - Mo.js

Desafio #92daysofcode que fiz no final de 2019. Nesse artigo temos o dia 69, mostrando o uso do Motion JS.

Pré-visualização

Código

Começamos com a estrutura do HTML.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
<!DOCTYPE html>
<html lang="pt-br">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Day 69</title>
<style>
*, *:before, *:after { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing:border-box; }
html { -webkit-box-sizing:border-box; -moz-box-sizing:border-box; box-sizing:border-box; font-size: 62.5%; }
* { margin: 0; padding: 0; list-style: none; outline: none; }
body { background: #000; color: #fff; font-family: Arial, Helvetica, sans-serif; }

.container { margin: 60px auto; max-width: 992px; width: 100%; }
</style>
<link rel="stylesheet" type="text/css" href="./day-69.css">
</head>
<body>
<div class="container">
<div class="game"></div>
<div class="end"></div>
</div>
<script src="./node_modules/@mojs/core/build/mo.min.js"></script>
<script src="./day.js"></script>
</body>
</html>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
:root {
--blue: #5dbdc1;
--red: #ff9292;
}

body { height: 100vh; }

.game {
display: flex;
flex-direction: row;
flex-flow: wrap row;
position: absolute;
left: 0;
right: 0;
top: 0;
bottom: 0;
margin: auto;
width: 510px;
height: 210px;
border-radius: 9px;
background-color: #333;
padding: 5px;
}

.item {
height: 100px;
width: 100px;
margin: 0;
padding: 0px;
text-align: center;
border-radius: 9px;
border: 4px solid #333;
background-color: #000;
background-position: center;
background-size: 70%;
background-repeat: no-repeat;
cursor: pointer;
}

.blue,
.red { animation-name: getIn; animation-duration: 0.3s; animation-timing-function: cubic-bezier(0.68, -0.55, 0.265, 1.55); }

.blue { background-color: var(--blue); }
.red { background-color: var(--red); }

.running {
background-image: url('data:image/svg+xml;base64,PHN2ZyBoZWlnaHQ9IjUxMnB0IiB2aWV3Qm94PSIwIC01NSA1MTIgNTEyIiB3aWR0aD0iNTEycHQiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PHBhdGggZD0ibTMwOS4xNzU3ODEgMTUyLjI1LTEyLjk5NjA5My0yMy42MzY3MTljLjQyOTY4Ny00LjgzMjAzMSAxLjI5Mjk2OC0xMC4zNDM3NSAyLjg3MTA5My0xNi4xOTUzMTIgNC42ODc1LTE3LjM4MjgxMyAxNi42NTIzNDQtNDEuMzc1IDQ3LjA2MjUtNTYuOTE3OTY5IDEwLjIzMDQ2OS01LjIzMDQ2OSAyMi43NDYwOTQtMS4xNzU3ODEgMjcuOTc2NTYzIDkuMDU0Njg4IDUuMjI2NTYyIDEwLjIxODc1IDEuMTcxODc1IDIyLjc0NjA5My05LjA0Njg3NSAyNy45NzY1NjItMjMuMzA0Njg4IDExLjkwMjM0NC0yNy4yODkwNjMgMzEuOTg4MjgxLTI3LjcxNDg0NCA0Mi4xNTIzNDR6bTAgMCIgZmlsbD0iIzQyOTdkMCIvPjxwYXRoIGQ9Im0zNzAuOTM3NSA2MC4wMTE3MTljLTIuODk4NDM4LjEyNS01LjgyMDMxMi44NjMyODEtOC41NzQyMTkgMi4yNjU2MjUtMzAuNDEwMTU2IDE1LjU0Mjk2OC00Mi4zNzUgMzkuNTM1MTU2LTQ3LjA2MjUgNTYuOTE3OTY4LTEuNTgyMDMxIDUuODUxNTYzLTIuNDQ1MzEyIDExLjM2MzI4Mi0yLjg3MTA5MyAxNi4xOTUzMTNsNi4wNzAzMTIgMTEuMDQyOTY5LTkuMzI0MjE5IDUuODIwMzEyLTEyLjk5NjA5My0yMy42NDA2MjVjLjQyOTY4Ny00LjgzMjAzMSAxLjI5Mjk2OC0xMC4zNDM3NSAyLjg3MTA5My0xNi4xOTUzMTIgNC42ODc1LTE3LjM4MjgxMyAxNi42NTIzNDQtNDEuMzc1IDQ3LjA2MjUtNTYuOTE3OTY5IDguNTQ2ODc1LTQuMzY3MTg4IDE4LjY3MTg3NS0yLjI1NzgxMiAyNC44MjQyMTkgNC41MTE3MTl6bTAgMCIgZmlsbD0iIzE4NzZhOSIvPjxwYXRoIGQ9Im01MTAuMTA5Mzc1IDMyMy44Mzk4NDQtOC45MjE4NzUgMjUuOTc2NTYyYy0xMS45MzM1OTQgMzIuOTQ1MzEzLTQ2Ljc1IDUyLjYwNTQ2OS04Mi44MDA3ODEgNTAuMjk2ODc1bC0xMjkuOTkyMTg4IDEuMTUyMzQ0Yy0yNy42NTIzNDMtMS43NjU2MjUtNTMuOTQ1MzEyLTEyLjI1MzkwNi03NC44MjAzMTItMjkuODY3MTg3bC0xMDUuNjQwNjI1LTgyLjcxODc1Yy05LjUzNTE1Ni03LjQ2NDg0NC0xNS4wMzEyNS0xOC44NTkzNzYtMTUuMDMxMjUtMzAuODM1OTM4IDAtMS4xMjEwOTQuMDUwNzgxLTIuMjUzOTA2LjE0NDUzMS0zLjM4NjcxOS4wNzAzMTMtLjgzMjAzMS4xMDE1NjMtMS42NTIzNDMuMTAxNTYzLTIuNDc2NTYyIDAtMTQuNTYyNS0xMS4wODIwMzItMjcuMTQwNjI1LTI2LjI2OTUzMi0yOS4yMzA0NjktMTAuMTEzMjgxLTEuNDA2MjUtMTkuMzM1OTM3LTYuNTcwMzEyLTI1Ljc5Mjk2OC0xNC40ODQzNzVsLTMxLjczODI4Mi0zOC44OTg0MzdjLTEzLjI5Njg3NS0xNi4yNjk1MzItMTEuMzcxMDk0LTM5LjY5MTQwNyA0LjQxNzk2OS01My43MzgyODJsNDUuMjAzMTI1LTM2LjI5Mjk2OCAzOS40NzI2NTYgMjEuMzk4NDM3em0wIDAiIGZpbGw9IiNlNWU1ZTUiLz48cGF0aCBkPSJtNDE4LjM4NjcxOSA0MDAuMTEzMjgxLTEyOS45OTIxODggMS4xNTIzNDRjLTI3LjY1MjM0My0xLjc2NTYyNS01My45NDUzMTItMTIuMjUzOTA2LTc0LjgyMDMxMi0yOS44NjcxODdsLTEwNS42NDA2MjUtODIuNzE4NzVjLTkuNTM1MTU2LTcuNDY0ODQ0LTE1LjAzMTI1LTE4Ljg1OTM3Ni0xNS4wMzEyNS0zMC44MzU5MzggMC0xLjEyMTA5NC4wNTA3ODEtMi4yNTM5MDYuMTQ0NTMxLTMuMzg2NzE5LjA3MDMxMy0uODMyMDMxLjEwMTU2My0xLjY1MjM0My4xMDE1NjMtMi40NzY1NjIgMC0xNC41NjI1LTExLjA4MjAzMi0yNy4xNDA2MjUtMjYuMjY5NTMyLTI5LjIzMDQ2OS0xMC4xMTMyODEtMS40MDYyNS0xOS4zMzU5MzctNi41NzAzMTItMjUuNzkyOTY4LTE0LjQ4NDM3NWwtMzEuNzM4MjgyLTM4Ljg5ODQzN2MtMTMuMjk2ODc1LTE2LjI2OTUzMi0xMS4zNzEwOTQtMzkuNjkxNDA3IDQuNDE3OTY5LTUzLjczODI4Mmw0NS4yMDMxMjUtMzYuMjkyOTY4IDM5LjQ3MjY1NiAyMS4zOTg0MzctMjkuNDcyNjU2IDU2LjEwNTQ2OXMtMjguMDM1MTU2IDExLjY3MTg3NS02LjM2MzI4MSAzMy4zNDc2NTZjMTUuMjczNDM3IDE1LjI3MzQzOCA5NC4xMTcxODcgOTQuMTE3MTg4IDEzOS4zNTU0NjkgMTM5LjM1NTQ2OSAyMC44OTg0MzcgMjAuODk4NDM3IDQ3LjQyOTY4NyAzNS4yNDIxODcgNzYuMzU1NDY4IDQxLjI4OTA2MnptMCAwIiBmaWxsPSIjY2JjYmNiIi8+PHBhdGggZD0ibTUxMiAzMTEuMDMxMjVjMCAxMS45NDUzMTItNS4wMTE3MTkgMjIuNzQ2MDk0LTEzLjEwOTM3NSAzMC41NzQyMTktOC4wOTc2NTYgNy44MTY0MDYtMTkuMjg1MTU2IDEyLjY2MDE1Ni0zMS42NDQ1MzEgMTIuNjYwMTU2aC0xMjIuOTI5Njg4Yy00NS44Nzg5MDYgMC04OS44NzUtMTcuNjUyMzQ0LTEyMi4yNjk1MzEtNDkuMDQ2ODc1bC0xMTAuNDY0ODQ0LTEwNy4wNjY0MDZ2LS4wMTE3MTlsLTU2Ljk4ODI4MS01NS4yMzA0NjljLTguMTcxODc1LTcuOTE0MDYyLTEyLjQ3NjU2Mi0xOC4xNDA2MjUtMTIuODgyODEyLTI4LjQ5NjA5NC0uNTM5MDYzLTEzLjY1MjM0MyA2LjEyNS0yNi42NDQ1MzEgMTcuMjU3ODEyLTM1LjA3ODEyNGwxMDEuNDcyNjU2LTc2Ljc3MzQzOGM1Ljk4ODI4Mi01Ljc3NzM0NCAxNi4xNzU3ODItMS4wNzgxMjUgMTUuMjgxMjUgNy4wNTg1OTQtLjQxNDA2MiAzLjgxNjQwNi0uNjIxMDk0IDcuNjAxNTYyLS42MjEwOTQgMTEuMzU1NDY4IDAgMjIuMTgzNTk0IDcuMTgzNTk0IDQzLjA3ODEyNiAxOS41OTM3NSA2MC4zNDc2NTcgMTcuNjQ0NTMyIDI0LjU1NDY4NyA0NS44NTkzNzYgNDEuNzg5MDYyIDc5LjA1MDc4MiA0NS4wNzQyMTlsNTIuNDQ5MjE4IDUuMTg3NWMxMi4zMjgxMjYgMS4yMTg3NSAyMi44NzEwOTQgOS4wOTc2NTYgMjcuMTgzNTk0IDIwLjMyNDIxOGwzNiA5My44MDQ2ODggMS40MDYyNSAxLjM1MTU2MmM3LjczNDM3NSAzLjM5ODQzOCAyMi43OTY4NzUgNy40OTIxODggNjQuMjc3MzQ0IDE0LjU2MjUgMjcuMzM5ODQ0IDQuNjY3OTY5IDUzLjU0Njg3NSAxNS42NzU3ODIgNTYuOTM3NSA0OS40MDIzNDR6bTAgMCIgZmlsbD0iIzQyOTdkMCIvPjxwYXRoIGQ9Im0xMTEuNTgyMDMxIDE5OC4xNDA2MjUtNTYuOTg4MjgxLTU1LjIzMDQ2OWMtOC4xNzE4NzUtNy45MTQwNjItMTIuNDc2NTYyLTE4LjE0MDYyNS0xMi44ODI4MTItMjguNDk2MDk0LS41MzkwNjMtMTMuNjUyMzQzIDYuMTI1LTI2LjY0NDUzMSAxNy4yNTc4MTItMzUuMDc4MTI0bDEwMS40NzI2NTYtNzYuNzczNDM4YzUuOTg4MjgyLTUuNzc3MzQ0IDE2LjE3NTc4Mi0xLjA3ODEyNSAxNS4yODEyNSA3LjA1ODU5NC0uNDE0MDYyIDMuODE2NDA2LS42MjEwOTQgNy42MDE1NjItLjYyMTA5NCAxMS4zNTU0NjggMCAyMi4xODM1OTQgNy4xODM1OTQgNDMuMDc4MTI2IDE5LjU5Mzc1IDYwLjM0NzY1NyAwIDAtOTIuMzg2NzE4IDUyLjk3NjU2Mi04My4xMTMyODEgMTE2LjgxNjQwNnptMCAwIiBmaWxsPSIjMTg3NmE5Ii8+PHBhdGggZD0ibTM0Mi41MDc4MTIgMjA5LjE5OTIxOS0xNTMuODcxMDkzIDYzLjYzMjgxMi0xMzQuMDQyOTY5LTEyOS45Mjk2ODdjLTguMTc5Njg4LTcuOTEwMTU2LTEyLjQ3NjU2Mi0xOC4xNDA2MjUtMTIuODc4OTA2LTI4LjQ5MjE4OC0uMDU0Njg4LTEuMzEyNS0uMDQyOTY5LTIuNjIxMDk0LjAzOTA2Mi0zLjkyMTg3NWwyNjAuNjQ4NDM4IDU1Ljc2NTYyNXptMCAwIiBmaWxsPSIjZjJmMmYyIi8+PHBhdGggZD0ibTQ1NS4wNTg1OTQgMjYxLjYzMjgxMmMtMTIuNTM5MDYzIDI1LjAwMzkwNy00MC4yNzM0MzggMzguNDk2MDk0LTY3LjY3NTc4MiAzMi45Mzc1bC0yNy4yNjk1MzEtNS41MzEyNWMtMTIuMjE0ODQzLTIuNDg0Mzc0LTIyLjEyMTA5My0xMS4zNjMyODEtMjUuOTE3OTY5LTIzLjIzNDM3NGwtNDQuMDAzOTA2LTEzNy43NzczNDQgMzYgMy41NjY0MDZjMTIuMzM5ODQ0IDEuMjE0ODQ0IDIyLjg3MTA5NCA5LjA5Mzc1IDI3LjE4MzU5NCAyMC4zMjQyMTlsMzYuMDAzOTA2IDkzLjgwMDc4MSAxLjQwMjM0NCAxLjM1MTU2MmM3LjczNDM3NSAzLjM5ODQzOCAyMi43OTY4NzUgNy40OTYwOTQgNjQuMjc3MzQ0IDE0LjU2MjV6bTAgMCIgZmlsbD0iI2ZjYjUyZiIvPjxwYXRoIGQ9Im0xMzUuMjEwOTM4IDIyMS4wNDI5NjktMjMuNjI4OTA3LTIyLjkwMjM0NC01Ni45ODA0NjktNTUuMjMwNDY5Yy04LjE3OTY4Ny03LjkxNDA2Mi0xMi40NzI2NTYtMTguMTQwNjI1LTEyLjg5MDYyNC0yOC40OTYwOTQtLjUzMTI1LTEzLjY1MjM0MyA2LjEyNS0yNi42NDQ1MzEgMTcuMjU3ODEyLTM1LjA3ODEyNGw3Ni4yNDIxODgtNTcuNjc1NzgyczIxLjMwMDc4MSAzNS45ODA0NjkgMzAuNzkyOTY4IDc5Ljc0NjA5NGM4LjgzNTkzOCA0MC43MDMxMjUgNy40NTMxMjUgODguMTQ4NDM4LTMwLjc5Mjk2OCAxMTkuNjM2NzE5em0wIDAiIGZpbGw9IiNmY2I1MmYiLz48cGF0aCBkPSJtMTExLjU4MjAzMSAxOTguMTQwNjI1LTU2Ljk4MDQ2OS01NS4yMzA0NjljLTguMTc5Njg3LTcuOTE0MDYyLTEyLjQ3MjY1Ni0xOC4xNDA2MjUtMTIuODkwNjI0LTI4LjQ5NjA5NC0uNTMxMjUtMTMuNjUyMzQzIDYuMTI1LTI2LjY0NDUzMSAxNy4yNTc4MTItMzUuMDc4MTI0bDc2LjI0MjE4OC01Ny42NzU3ODJzMjEuMzAwNzgxIDM1Ljk4MDQ2OSAzMC43OTI5NjggNzkuNzQ2MDk0Yy0yNi4yNTc4MTIgMjEuMTM2NzE5LTYwLjIyMjY1NiA1Ni44MDQ2ODgtNTQuNDIxODc1IDk2LjczNDM3NXptMCAwIiBmaWxsPSIjZjk5ODMwIi8+PGcgZmlsbD0iI2U1ZTVlNSI+PHBhdGggZD0ibTM0MS44NjcxODggMTc3Ljc3MzQzOGMtNy4wNTQ2ODggMC0xMy40NDkyMTktNC44MTY0MDctMTUuMTU2MjUtMTEuOTgwNDY5LTEuOTk2MDk0LTguMzc1IDMuMTc1NzgxLTE2Ljc4NTE1NyAxMS41NTA3ODEtMTguNzg1MTU3bDI5LjMzMjAzMS02Ljk5MjE4N2M4LjM3ODkwNi0yIDE2Ljc4OTA2MiAzLjE3MTg3NSAxOC43ODUxNTYgMTEuNTUwNzgxIDIgOC4zNzUtMy4xNzE4NzUgMTYuNzg1MTU2LTExLjU1MDc4MSAxOC43ODUxNTZsLTI5LjMzMjAzMSA2Ljk5NjA5NGMtMS4yMTQ4NDQuMjg5MDYzLTIuNDMzNTk0LjQyNTc4Mi0zLjYyODkwNi40MjU3ODJ6bTAgMCIvPjxwYXRoIGQ9Im0zNTkuMDgyMDMxIDIzMS44Mzk4NDRjLTcuMDUwNzgxIDAtMTMuNDQ1MzEyLTQuODIwMzEzLTE1LjE1MjM0My0xMS45ODA0NjktMi04LjM3ODkwNiAzLjE3NTc4MS0xNi43ODkwNjMgMTEuNTUwNzgxLTE4Ljc4NTE1NmwyOS4zMzIwMzEtNi45OTYwOTRjOC4zNzUtMiAxNi43ODkwNjIgMy4xNzE4NzUgMTguNzg1MTU2IDExLjU1MDc4MSAyIDguMzc4OTA2LTMuMTc1NzgxIDE2Ljc4OTA2My0xMS41NTA3ODEgMTguNzg1MTU2bC0yOS4zMzIwMzEgNi45OTYwOTRjLTEuMjE0ODQ0LjI4OTA2My0yLjQzMzU5NC40Mjk2ODgtMy42MzI4MTMuNDI5Njg4em0wIDAiLz48cGF0aCBkPSJtMTM4LjI1NzgxMiAzODIuMjMwNDY5aC05Ny41NDI5NjhjLTQuMzA4NTk0IDAtNy43OTY4NzUtMy40OTIxODgtNy43OTY4NzUtNy43OTY4NzUgMC00LjMwODU5NCAzLjQ4ODI4MS03Ljc5Njg3NSA3Ljc5Njg3NS03Ljc5Njg3NWg5Ny41NDI5NjhjNC4zMDQ2ODggMCA3Ljc5Njg3NiAzLjQ4ODI4MSA3Ljc5Njg3NiA3Ljc5Njg3NSAwIDQuMzA0Njg3LTMuNDkyMTg4IDcuNzk2ODc1LTcuNzk2ODc2IDcuNzk2ODc1em0wIDAiLz48cGF0aCBkPSJtNTkuNjc5Njg4IDMwNy43MTQ4NDRoLTUxLjg4MjgxM2MtNC4zMDg1OTQgMC03Ljc5Njg3NS0zLjQ4ODI4Mi03Ljc5Njg3NS03Ljc5Njg3NSAwLTQuMzA0Njg4IDMuNDg4MjgxLTcuNzk2ODc1IDcuNzk2ODc1LTcuNzk2ODc1aDUxLjg4MjgxM2M0LjMwODU5MyAwIDcuNzk2ODc0IDMuNDkyMTg3IDcuNzk2ODc0IDcuNzk2ODc1IDAgNC4zMDg1OTMtMy40ODgyODEgNy43OTY4NzUtNy43OTY4NzQgNy43OTY4NzV6bTAgMCIvPjwvZz48L3N2Zz4=');
}

.hamburguer {
background-image: url('data:image/svg+xml;base64,<svg id="Capa_1" enable-background="new 0 0 512 512" height="512" viewBox="0 0 512 512" width="512" xmlns="http://www.w3.org/2000/svg"><path d="m256 88c-26.69 0-52.393 1.686-76.483 4.807-99.539 12.895-133.517 50.282-133.517 94.393v12.8c0 4.418 3.582 8 8 8h442c4.418 0 8-3.582 8-8v-12.8c0-54.787-111.033-99.2-248-99.2z" fill="#ffd97d"/><path d="m168 200c-13.255 0-24-10.745-24-24v-32c0-18.722 12.981-36.253 35.518-51.194-99.528 12.898-171.518 50.286-171.518 94.394v20.8c0 4.418 3.582 8 8 8h16l13 13.5h420.5l14.5-13.5h16c4.418 0 8-3.582 8-8v-8z" fill="#ffc269"/><path d="m120 160c-2.047 0-4.094-.781-5.656-2.344-3.125-3.125-3.125-8.188 0-11.313l8-8c3.125-3.125 8.188-3.125 11.313 0s3.125 8.188 0 11.313l-8 8c-1.563 1.563-3.61 2.344-5.657 2.344z" fill="#f9eac7"/><path d="m224 144c-2.047 0-4.094-.781-5.656-2.344l-8-8c-3.125-3.125-3.125-8.188 0-11.313s8.188-3.125 11.313 0l8 8c3.125 3.125 3.125 8.188 0 11.313-1.563 1.563-3.61 2.344-5.657 2.344z" fill="#ecbd83"/><path d="m336 184c-2.047 0-4.094-.781-5.656-2.344l-8-8c-3.125-3.125-3.125-8.188 0-11.313s8.188-3.125 11.313 0l8 8c3.125 3.125 3.125 8.188 0 11.313-1.563 1.563-3.61 2.344-5.657 2.344z" fill="#ecbd83"/><path d="m384 168c-2.047 0-4.094-.781-5.656-2.344-3.125-3.125-3.125-8.188 0-11.313l8-8c3.125-3.125 8.188-3.125 11.313 0s3.125 8.188 0 11.313l-8 8c-1.563 1.563-3.61 2.344-5.657 2.344z" fill="#f9eac7"/><path d="m304 144c-4.422 0-8-3.582-8-8v-8c0-4.418 3.578-8 8-8s8 3.582 8 8v8c0 4.418-3.578 8-8 8z" fill="#f9eac7"/><path d="m184 184h-8c-4.422 0-8-3.582-8-8s3.578-8 8-8h8c4.422 0 8 3.582 8 8s-3.578 8-8 8z" fill="#ecbd83"/><path d="m256 184c-2.047 0-4.094-.781-5.656-2.344-3.125-3.125-3.125-8.188 0-11.313l8-8c3.125-3.125 8.188-3.125 11.313 0s3.125 8.188 0 11.313l-8 8c-1.563 1.563-3.61 2.344-5.657 2.344z" fill="#f9eac7"/><path d="m432 184h-8c-4.422 0-8-3.582-8-8s3.578-8 8-8h8c4.422 0 8 3.582 8 8s-3.578 8-8 8z" fill="#ecbd83"/><path d="m80 184c-2.047 0-4.094-.781-5.656-2.344l-8-8c-3.125-3.125-3.125-8.188 0-11.313s8.188-3.125 11.313 0l8 8c3.125 3.125 3.125 8.188 0 11.313-1.563 1.563-3.61 2.344-5.657 2.344z" fill="#ffd97d"/><path d="m168.078 144c-4.422 0-8.039-3.582-8.039-8s3.539-8 7.961-8h.078c4.422 0 8 3.582 8 8s-3.578 8-8 8z" fill="#f9eac7"/><path d="m352 144c-4.422 0-8.039-3.582-8.039-8s3.539-8 7.961-8h.078c4.422 0 8 3.582 8 8s-3.578 8-8 8z" fill="#ecbd83"/><path d="m264.078 128c-4.422 0-8.039-3.582-8.039-8s3.539-8 7.961-8h.078c4.422 0 8 3.582 8 8s-3.578 8-8 8z" fill="#f9eac7"/><path d="m445 288h-374.667l-30.333-24v-24h432v24.333z" fill="#95d6a4"/><path d="m90.624 288h165.319c-41.337 0-41.337-32-82.674-32-41.323 0-41.323 32-82.645 32z" fill="#78c2a4"/><path d="m255.943 288h165.353c-41.352 0-41.352-32-82.705-32-41.324 0-41.324 32-82.648 32z" fill="#78c2a4"/><path d="m176 248h-144c-4.418 0-8-3.582-8-8v-16c0-4.418 3.582-8 8-8h144c4.418 0 8 3.582 8 8v16c0 4.418-3.582 8-8 8z" fill="#db4655"/><path d="m480 248h-144c-4.418 0-8-3.582-8-8v-16c0-4.418 3.582-8 8-8h144c4.418 0 8 3.582 8 8v16c0 4.418-3.582 8-8 8z" fill="#ff8086"/><path d="m336 248h-160c-4.418 0-8-3.582-8-8v-16c0-4.418 3.582-8 8-8h160c4.418 0 8 3.582 8 8v16c0 4.418-3.582 8-8 8z" fill="#e5646e"/><path d="m472 336h-323.5l-43-24c0-17.673 17.265-32 34.938-32h331.562c17.673 0 32 14.327 32 32 0 5.828-1.558 11.293-4.281 15.999z" fill="#c86e64"/><path d="m168 328c-17.673 0-32-14.327-32-32 0-5.859 1.689-11.277 4.438-16h-100.438c-17.673 0-32 14.327-32 32s14.327 32 32 32l14.5 10.5h404l13.5-10.5c11.814 0 22.178-6.476 27.721-16z" fill="#b4505a"/><path d="m103.992 352c-1.203 0-2.422-.27-3.57-.844-3.953-1.977-5.555-6.781-3.578-10.734l8-16c1.984-3.957 6.773-5.559 10.734-3.578 3.953 1.977 5.555 6.781 3.578 10.734l-8 16c-1.406 2.805-4.226 4.422-7.164 4.422z" fill="#c86e64"/><g fill="#e66e64"><path d="m352 304c-2.047 0-4.094-.781-5.656-2.344l-16-16c-3.125-3.125-3.125-8.188 0-11.313s8.188-3.125 11.313 0l16 16c3.125 3.125 3.125 8.188 0 11.313-1.563 1.563-3.61 2.344-5.657 2.344z"/><path d="m312 320h-8c-4.422 0-8-3.582-8-8s3.578-8 8-8h8c4.422 0 8 3.582 8 8s-3.578 8-8 8z"/><path d="m176 328c-2.047 0-4.094-.781-5.656-2.344l-8-8c-3.125-3.125-3.125-8.188 0-11.313s8.188-3.125 11.313 0l8 8c3.125 3.125 3.125 8.188 0 11.313-1.563 1.563-3.61 2.344-5.657 2.344z"/></g><path d="m64 312c-2.047 0-4.094-.781-5.656-2.344-3.125-3.125-3.125-8.188 0-11.313l8-8c3.125-3.125 8.188-3.125 11.313 0s3.125 8.188 0 11.313l-8 8c-1.563 1.563-3.61 2.344-5.657 2.344z" fill="#c86e64"/><path d="m440.008 352c-2.938 0-5.758-1.617-7.164-4.422l-8-16c-1.977-3.953-.375-8.758 3.578-10.734 3.945-1.98 8.75-.379 10.734 3.578l8 16c1.977 3.953.375 8.758-3.578 10.734-1.148.574-2.367.844-3.57.844z" fill="#c86e64"/><path d="m472 320h-8c-4.422 0-8-3.582-8-8s3.578-8 8-8h8c4.422 0 8 3.582 8 8s-3.578 8-8 8z" fill="#e66e64"/><path d="m240 352c-4.422 0-8-3.582-8-8v-8c0-4.418 3.578-8 8-8s8 3.582 8 8v8c0 4.418-3.578 8-8 8z" fill="#c86e64"/><path d="m456 417h-318c-26.51 0-48-21.49-48-48v-9l54-16h344c8.837 0 16 7.163 16 16v16c0 12.295-4.623 23.511-12.225 32.004z" fill="#ffd97d"/><path d="m192 408c-26.51 0-48-21.49-48-48v-16h-120c-8.836 0-16 7.163-16 16v16c0 26.51 21.49 48 48 48h400c14.198 0 26.983-6.201 35.771-16z" fill="#ffc269"/><path d="m421.297 296c-23.406 0-35.539-9.391-46.25-17.672-9.93-7.688-18.508-14.328-36.453-14.328-17.93 0-26.5 6.641-36.43 14.328-10.695 8.281-22.828 17.672-46.219 17.672-23.398 0-35.531-9.391-46.234-17.672-9.93-7.688-18.508-14.328-36.445-14.328-17.922 0-26.5 6.637-36.422 14.324-10.696 8.285-22.821 17.676-46.219 17.676-23.391 0-35.516-9.391-46.211-17.676-9.922-7.687-18.492-14.324-36.414-14.324-4.422 0-8-3.582-8-8s3.578-8 8-8c23.391 0 35.516 9.391 46.211 17.676 9.922 7.687 18.492 14.324 36.414 14.324s26.5-6.637 36.422-14.324c10.695-8.285 22.82-17.676 46.219-17.676 23.406 0 35.539 9.391 46.242 17.676 9.93 7.688 18.508 14.324 36.438 14.324 17.922 0 26.492-6.637 36.422-14.324 10.702-8.285 22.827-17.676 46.226-17.676 23.406 0 35.539 9.391 46.25 17.672 9.93 7.688 18.508 14.328 36.453 14.328s26.523-6.641 36.453-14.328c10.711-8.281 22.844-17.672 46.25-17.672 4.422 0 8 3.582 8 8s-3.578 8-8 8c-17.945 0-26.523 6.641-36.453 14.328-10.711 8.281-22.844 17.672-46.25 17.672z" fill="#b3e59f"/></svg>');
}

.end { font-size: 10rem; text-align: center; }

@keyframes getIn {
from { background-size: 0%; }
to { background-size: 70%; }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
// The motion graphics toolbelt for the web
// https://github.com/mojs/mojs
class Game {
constructor(props) {
this.$game = props.$game;
this.$end = props.$end;

this.arrItem1 = [];
this.arrItem2 = [];
this.itemQuantities = 10;
this.colorClass1 = 'blue';
this.colorClass2 = 'red' ;
this.backgroundClass1 = 'running';
this.backgroundClass2 = 'hamburguer' ;
this.endMessage = 'FIM';

this.interval = 400;
this.newItem2 = setInterval(this.randomItem.bind(this), this.interval);

this.createGame();
this.init();
}

createGame() {
for (let i = 0; i < this.itemQuantities; i++) {
const div = document.createElement('div');
div.classList.add('item');
div.setAttribute('data-value', i);
this.$game.appendChild(div);
}
}

init() {
this.$items = document.querySelectorAll('.item');
this.$items.forEach(item => {
item.addEventListener('click', this.handleClick.bind(this));
});
}

randomItem() {
const a = Math.random() * this.itemQuantities;
const b = Math.floor(a);

if (!this.$items[b]) {
return;
}

if(this.arrItem2.indexOf(this.$items[b].dataset.value) == -1) {
this.arrItem2.push(this.$items[b].dataset.value);

this.$items[b].classList.remove(this.colorClass1);
this.$items[b].classList.add(this.colorClass2);
this.$items[b].classList.add(this.backgroundClass2);

if(this.arrItem2.length == this.itemQuantities) {
clearInterval(this.newItem2);

this.$end.innerHTML = this.endMessage;
this.$end.classList.add('red');
}
}

if(this.arrItem1.indexOf(this.$items[b].dataset.value) != -1) {
this.arrItem1.splice(this.arrItem1.indexOf(this.$items[b].dataset.value), 1);
}
}

handleClick(evt) {
const { target } = evt;

this.fire(evt);

if(this.arrItem1.indexOf(target.dataset.value) == -1) {
this.arrItem1.push(target.dataset.value);

if(this.arrItem1.length == this.itemQuantities) {
clearInterval(this.newItem2);

this.$end.innerHTML = this.endMessage;
this.$end.classList.add('blue');
}
}

if(this.arrItem2.indexOf(target.dataset.value) != -1) {
this.arrItem2.splice(this.arrItem2.indexOf(target.dataset.value) ,1);
}

target.classList.remove(this.colorClass2);
target.classList.remove(this.backgroundClass2);
target.classList.add(this.colorClass1);
target.classList.add(this.backgroundClass1);
}

fire(evt) {
const { target } = evt;
const itemDim = target.getBoundingClientRect();
const itemSize = {
x: itemDim.right - itemDim.left,
y: itemDim.bottom - itemDim.top,
};

const burst = new mojs.Burst({
left: itemDim.left + (itemSize.x/2),
top: itemDim.top + (itemSize.y/1.7),
count: 9,
radius: { 50 : 90 },
});

burst.play();
}
}

new Game({
$game: document.querySelector('.game'),
$end: document.querySelector('.end')
});

Conclusão

A postagem original pode ser vista no meu Instagram e o código está acessível no meu Github.

Relacionados

Ao fechar este aviso ou continuar navegando no site Nerd Calistênico, você aceita o uso de cookies.

Este site usa cookies para assegurar a melhor experiência para os nossos usuários. Consulte nossa política de privacidade.

Uma nova versão está disponível. Clique aqui para atualizar.