Skip to content

Commit f722971

Browse files
committed
finished files with 2.challenge
1 parent 7801d9f commit f722971

File tree

11 files changed

+136
-0
lines changed

11 files changed

+136
-0
lines changed

JavaScript Drum Kit/index.html

Lines changed: 83 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,83 @@
1+
<!DOCTYPE html>
2+
<html lang="en">
3+
<head>
4+
<meta charset="UTF-8">
5+
<title>JS Drum Kit</title>
6+
<link rel="stylesheet" href="style.css">
7+
</head>
8+
<body>
9+
10+
11+
<div class="keys">
12+
<div data-key="65" class="key">
13+
<kbd>A</kbd>
14+
<span class="sound">clap</span>
15+
</div>
16+
<div data-key="83" class="key">
17+
<kbd>S</kbd>
18+
<span class="sound">hihat</span>
19+
</div>
20+
<div data-key="68" class="key">
21+
<kbd>D</kbd>
22+
<span class="sound">kick</span>
23+
</div>
24+
<div data-key="70" class="key">
25+
<kbd>F</kbd>
26+
<span class="sound">openhat</span>
27+
</div>
28+
<div data-key="71" class="key">
29+
<kbd>G</kbd>
30+
<span class="sound">boom</span>
31+
</div>
32+
<div data-key="72" class="key">
33+
<kbd>H</kbd>
34+
<span class="sound">ride</span>
35+
</div>
36+
<div data-key="74" class="key">
37+
<kbd>J</kbd>
38+
<span class="sound">snare</span>
39+
</div>
40+
<div data-key="75" class="key">
41+
<kbd>K</kbd>
42+
<span class="sound">tom</span>
43+
</div>
44+
<div data-key="76" class="key">
45+
<kbd>L</kbd>
46+
<span class="sound">tink</span>
47+
</div>
48+
</div>
49+
50+
<audio data-key="65" src="sounds/clap.wav"></audio>
51+
<audio data-key="83" src="sounds/hihat.wav"></audio>
52+
<audio data-key="68" src="sounds/kick.wav"></audio>
53+
<audio data-key="70" src="sounds/openhat.wav"></audio>
54+
<audio data-key="71" src="sounds/boom.wav"></audio>
55+
<audio data-key="72" src="sounds/ride.wav"></audio>
56+
<audio data-key="74" src="sounds/snare.wav"></audio>
57+
<audio data-key="75" src="sounds/tom.wav"></audio>
58+
<audio data-key="76" src="sounds/tink.wav"></audio>
59+
60+
<script>
61+
62+
function playSound(e){
63+
const audio = document.querySelector(`audio[data-key="${e.keyCode}"]`),
64+
key = document.querySelector(`.key[data-key="${e.keyCode}"]`);
65+
if(!audio) return; //stop running the function if there is no audio associated with the key
66+
//hit the key and rewind to the start
67+
audio.currentTime = 0;
68+
audio.play();
69+
key.classList.add('playing'); //the same like in Jquery key.addClass('playing')
70+
}
71+
function removeTransition(e){
72+
if (e.propertyName != 'transform') return; //only works for transform
73+
this.classList.remove('playing');
74+
}
75+
const keys= document.querySelectorAll('.key'); //array of all the keys
76+
keys.forEach(key => key.addEventListener('transitionend', removeTransition));
77+
78+
window.addEventListener('keydown', playSound);
79+
</script>
80+
81+
82+
</body>
83+
</html>

JavaScript Drum Kit/sounds/boom.wav

130 KB
Binary file not shown.

JavaScript Drum Kit/sounds/clap.wav

63.4 KB
Binary file not shown.

JavaScript Drum Kit/sounds/hihat.wav

50.9 KB
Binary file not shown.

JavaScript Drum Kit/sounds/kick.wav

15.2 KB
Binary file not shown.
238 KB
Binary file not shown.

JavaScript Drum Kit/sounds/ride.wav

429 KB
Binary file not shown.

JavaScript Drum Kit/sounds/snare.wav

32.6 KB
Binary file not shown.

JavaScript Drum Kit/sounds/tink.wav

5.32 KB
Binary file not shown.

JavaScript Drum Kit/sounds/tom.wav

105 KB
Binary file not shown.

JavaScript Drum Kit/style.css

Lines changed: 53 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,53 @@
1+
html {
2+
font-size: 10px;
3+
background: url(https://images.unsplash.com/photo-1519530782816-ba0c305fbb0d?ixlib=rb-0.3.5&ixid=eyJhcHBfaWQiOjEyMDd9&s=59bc5229f1379f17f2c7a79c8550186d&auto=format&fit=crop&w=1050&q=80) bottom center;
4+
background-size: cover;
5+
}
6+
body,html {
7+
margin: 0;
8+
padding: 0;
9+
font-family: sans-serif;
10+
}
11+
12+
.keys {
13+
display: grid;
14+
grid-template-columns: 1fr 1fr 1fr;
15+
grid-gap: 1rem;
16+
max-width: 50%;
17+
margin: 0 auto;
18+
min-height: 100vh;
19+
align-items: center;
20+
justify-content: center;
21+
}
22+
23+
.key {
24+
border: .4rem solid black;
25+
border-radius: .5rem;
26+
margin: 1rem;
27+
font-size: 1.5rem;
28+
padding: 1rem .5rem;
29+
transition: all .07s ease;
30+
width: 10rem;
31+
text-align: center;
32+
color: white;
33+
background: rgba(0,0,0,0.4);
34+
text-shadow: 0 0 .5rem black;
35+
}
36+
37+
.playing {
38+
transform: scale(1.1);
39+
border-color: deeppink;
40+
box-shadow: 0 0 1rem deeppink;
41+
}
42+
43+
kbd {
44+
display: block;
45+
font-size: 4rem;
46+
}
47+
48+
.sound {
49+
font-size: 1.2rem;
50+
text-transform: uppercase;
51+
letter-spacing: .1rem;
52+
color: deeppink;
53+
}

0 commit comments

Comments
 (0)