Skip to content

Latest commit

 

History

History
163 lines (119 loc) · 4.49 KB

README.md

File metadata and controls

163 lines (119 loc) · 4.49 KB

simon-says-game

Play the game here! 🟢 🔴 🔵 🟡

This is my take on the classic game of Simon Says! Beat all 12 levels and brag to your friends.

This was my first project intended for General Assembly's Software Engineering Immersive. It is coded in HTML5, CSS3, and vanilla JavaScript. This game primarily showcases my understanding of asynchronous timing as well as DOM manipulation.

How to Play

  • Click "PLAY" button to begin the game.
  • The computer sequence will play.
  • Once the computer's sequence ends, it is the user's turn. Click the tiles in the order it was displayed.
  • If the sequence matches the computer's, you will move to the next round. Each round will add one more tile to the sequence.

Screenshots

1

2

3

Win Screen

4

Loss Screen

5

User Stories

  1. AAU, I want to click a button to start the game.
  startButton.addEventListener("click", startGame);
  startButton.classList.add("hidden");
  info.innerText = "Watch the sequence carefully!";
  level = 0;
  
  1. AAU, I want every level up to add one tile to the computer sequence.
  sequence.push(getRandomColor());
  playSequence(sequence);
  1. AAU, I want a randomly generated computer sequence to play.
  const randomColor = tiles[Math.floor(Math.random() * tiles.length)];
  return randomColor;
  1. AAU, I want the computer's sequence to illuminate tiles and play a corresponding sound at a timed interval.
  function playSequence(sequence) {
    sequence.forEach((color, index) => {
      setTimeout(() => {
        activateTile(color);
      }, index * 650);
    });
  }

  function activateTile(color) {
    const tile = document.querySelector(`[data-tile='${color}']`);
    const sound = document.querySelector(`[data-sound='${color}']`);

    tile.classList.remove("inactive");
    sound.play();

    setTimeout(() => {
      tile.classList.add("inactive");
    }, 300);
  }
  1. AAU, I want to click the tiles, only when it is my turn.
  function userTurn() {
    board.classList.remove("unclickable");
    info.innerText = "Your turn!";
  }
  1. AAU, I want my clicks' values be stored.
  board.addEventListener("click", (event) => {
  const { tile } = event.target.dataset;
  if (tile) handleClick(tile);
});

  userSequence.push(tile);
  1. AAU, If my sequence is wrong at any point, then I want the game to end.
  for (let i = 0; i < userSequence.length; i++) {
    if (userSequence[i] !== sequence[i]) {
      reset();
      return;
    }
  }
  1. AAU, If I enter the correct sequence, then I want to level up. If I have beaten a specific number of rounds, then I want to win the game.
  if (userSequence.length === sequence.length) {
    if (level === 5) {
      winGame();
    } else {
      info.innerText = "You're doing great! Keep it up!";
      setTimeout(levelUp, 1200);
      return;
    }
  }
  1. AAU, I want to see the screen change upon a win and a loss. I want my high score to be recorded. I also want to be able to replay.
//loss
    const sound = document.querySelector(`[data-sound='game-over']`);
    sound.play();
    
    document.body.style.background = "linear-gradient(to top, #EA8F8F, #C12727)";
    info.innerText = "Game over! 😈 Play again?";
    
//win
    const sound = document.querySelector(`[data-sound='game-win']`);
    sound.play();
    
    document.body.style.background = "linear-gradient(to top, #BEF1CB, #60BC77)";
    info.innerText = "Amazing work! 🤩 You win!";
    
//reset
    sequence = [];
    userSequence = [];
    level = 0;
    
//start button appears, board unclickable
    startButton.classList.remove("hidden");
    board.classList.add("unclickable");
  1. AAU, I want my high score to be updated and recorded.
    if (highScore < level) {
      highScore = level;
    }
    
    highScoreText.innerText = highScore;