/emojibops

EmojiBops is a listing of songs depicted through emojis. Perfect practice for your first open source pull request!

Primary LanguageJavaScriptOtherNOASSERTION

EmojiBops 🎢

A listing of songs depicted through emojis.

Visit emojibops.com

Screenshot of Emojibops homepage

This project was built to create a fun, judgement free space for those learning Git and Github to practice making pull requests, branches, adding features, and more. πŸ’› πŸ’™ πŸ’œ πŸ’š πŸ’–

Also contribute to our companion project, EmojiScreen: a listing of TV shows, movies and musicals depicted via emojis.

Contributing 🎁

Below are instructions for how to contribute to this project. The easiest way to make a contribution is to add an Emoji Card to the website (you can add multiple songs). Each card should be added in the data.js file as an object.

For more advanced ways to contribute, see the repo Issues under the label 'enhancement'. If you want to work on one of the features but aren't sure where to start, write a comment and I will be happy to help you out or get you started. You are also welcome to suggest other features by adding an Issue.

Read below for a detailed overview and walkthrough on how to add an Emoji Card to this project. First time pull-requests are encouraged and you can make multiple pull requests if you desire. If you run into trouble, feel free to create an Issue!

Table of Contents

Choosing a Song to Add

Here are some links to lists of songs in case you're having trouble thinking of something to add!

Songs added must have lyrics, no instrumental songs please.

I have also added Issues for individual songs that I think would be fun to add to EmojiBops. The Issues are also categoried into loose genre categories of Pop, Hip Hop, Rock, Country, Musicals, Disney and R&B.

Feel free to add any of the songs listed in Issues. Make sure to comment inside of the Issue if you plan on taking it and add the Issue number in your Pull Request.

Note: The issues to add songs have links to a Wikipedia or other page with song information, but many songs have multiple versions. Feel free to add a different version than the link if you prefer.

Songs

Albums

Artists

Card Overview

On the website, each Emoji Card displays 1) images of the emojis, 2) a hint icon that will show the year the song was released (when the user hovers) and 3) the name of the song, the artist name and a link to the music video (which appears when the user clicks on a card).

Screenshot of emoji cards

In the data.js file, each Emoji Card consists of the following object:

{
  title: "Boy With Luv",
  artist: ["BTS"],
  featuredArtist: ["Halsey"],
  emojiImgs: "πŸ§’πŸ»πŸ’œπŸ“Έ",
  musicVideo: "https://www.youtube.com/watch?v=XsX3ATc3FbA",
  genres: ["k-pop", "pop"],
  year: 2019
}

To add a new card to the website, add a new object in the data.js file. Make sure to separate your new object from existing objects with a comma. Below is an overview of each key in the Emoji Card object. Every key is required.

Title πŸ‘

Each card must have a title. This should not included featured artist names, that is added seperately so we can filter by those artist names later.

{
  title: "Boy With Luv",
}

Emojis 😍

The emojis should be added to emojiImgs as a string. Your emojis should be surrounded by double quotation marks.

Important Note: Add six emojis maximum for each card

{
  emojiImgs: "πŸ§’πŸ»πŸ’œπŸ“Έ",
}

Using JavaScript, the emojis are converted into Twemoji (Twitter's emoji version) so that all emojis will be uniform across platforms. And because they are pretty cute. πŸ’–

Here are a few resources to find emojis to copy:

  • Twitter Emojis - Shows you what each Twitter emoji looks like.
  • Get Emoji and EmojiCopy are tools to copy regular emojis easily from one page. Note: The initial homepage does not display all skin color versions of each emoji so you will need to search in Emojipedia for those.
  • Emojipedia - A directory of all emojis.

Note when you copy these emojis and paste them into your text editor or Github, they will no longer look like the Twitter emojis. But don't worry, Javascript will convert them to the Twitter emojis on the EmojiBops website.

Genres πŸ”

The genres should be added as an array (the square [] brackets indicates an array or list). Separate each genre with a comma and each genre should be wrapped in quotes. There is no limit to the number of genres but try not to add too many.

{
  genres: ["k-pop", "pop"],
}

Select your genres from this list of genres. If you want to use a genre that is not on this list, in your pull request please add the genre to the genres.md file.

If you need help selecting genres, you can sometimes find genres on the song's Wikipedia page.

Artist 🎬

The artist(s) should be added as an array (the square [] brackets indicates an array or list). Separate each artist with a comma and each artist should be wrapped in quotes. An example with multiple artists: artist: ["Lady Gaga", "Bradley Cooper"]

For musicals, the artist should be the name of the show.

{
  artist: ["BTS"],
}

Featured Artist 🎬

The featured artist(s) should be added as an array (the square [] brackets indicates an array or list). Separate each artist with a comma and each artist should be wrapped in quotes. An example with multiple featured artists: featuredArtist: ["Justin Bieber", "Lil Wayne", "Quavo", "Chance the Rapper"]

{
  featuredArtist: ["Halsey"],
}

Music Video

Add a link to the official music video if there is one. If there is no music video, then add a link to a performance of the song (such as on an awards show, talk show, etc). If you are not able to find a music video or performance, just try to use your best judgement when selecting a video for the song. If there are no videos, leave this item blank like so: musicVideo: ""

The link must have https or http included.

{
  musicVideo: "https://www.youtube.com/watch?v=XsX3ATc3FbA",
}

Year πŸ“†

Specify the year the song was released.

{
  year: 1994
}

Walkthrough

Follow these instructions to add a card. You can add a card using the Github website user interface or on your local machine. If you do not already have one, create a Github account before proceeding.

If you are already comfortable using Github and Git, feel free to skip the instructions below and make a pull request using whatever method you prefer!

Github UI

This method will use the Github website to contribute to this project. You will not need to download any programs to your computer using these instructions.

  1. Check the Issues to see if the song is listed. Issues by Genre: Pop, Hip Hop, Rock, Country, Musicals, Disney and R&B.
  • If it is not listed as an issue, continue to the next step.
  • If it is listed as an Issue, take note of the Issue number (the number next to the title of the Issue) so that you can add it to your pull request and write a comment in the Issue stating that you will be adding that particular song. If there is already a comment in the Issue from someone saying that they will add that song, choose something else to add.
  1. Fork this repository. This will create a copy of the repository and create a new repository on your account. Note: the Fork button is located in the top right area of the repo.
  2. Once the repo is forked, you will be taken to the forked repo. Note: In the top left, the name of the repo should now include your username.
  3. Navigate to the data.js file in your forked repo by clicking on the file name.
  4. Edit the data.js file by clicking on the pencil icon and add a new object for your song in alphabetical order. Note: If the song title starts with 'The' then use the next word for alphabetical order. Make sure there is a comma between your object and the object above and below. Refer to the card overview above for requirements for the different object keys.

Use the following object as a template:

{
  title: "Old Town Road",
  artist: ["Lil Nas X"],
  featuredArtist: ["Billy Ray Cyrus"],
  emojiImgs: "πŸŽπŸ›£οΈπŸŽΈπŸ€ ",
  musicVideo: "https://www.youtube.com/watch?v=w2Ov5jzm3j8",
  genres: ["hip-hop", "country"],
  year: 2019
}
  1. Once you have completed updating the object for your song, scroll to the bottom of the page and add a commit message. The commit message should be formatted like: Added Wannabe by the Spice Girls or Added thank u next by Ariana. Click the Commit Changes button to save your changes.

Screenshot of creating a commit message on the Github website

  1. Navigate to the Pull Request tab. Click on New Pull Request.

Screenshot of a Pull Request on the Github website

  1. Review your changes and then click Create Pull Request. Add any additional comments, go through the checklist within the Pull Request and add an Issue number if applicable, then click on Create Pull Request.
  2. Wait for feedback/review of your Pull Request. Your code will be reviewed and if any changes need to be made, we will let you know. Once your pull request is accepted, you will be able to see your card at https://emojibops.com and you will officially have contributed to the project! πŸŽ‰

Local Development

This method will use your local machine to contribute to the project. This will require you to download multiple programs onto your computer. This is the method most programmers use when working on projects.

Required Downloads & Tools

  • Terminal (Mac OS) or Command Prompt. These are installed by default on your computer. Search for the program to open it. For Windows, Git Bash is recommended.
  • Git - This is a version control tool. For Windows, this download will include Git Bash.
  • A text editor such as Sublime Text, Atom, Visual Studio Code, etc.

Local Development Instructions

  1. Check the Issues to see if the song is listed. Issues by Genre: Pop, Hip Hop, Rock, Country, Musicals, Disney and R&B.
  • If it is not listed as an issue, continue to the next step.
  • If it is listed as an Issue, take note of the Issue number (the number next to the title of the Issue) so that you can add it to your pull request and write a comment in the Issue stating that you will be adding that particular song. If there is already a comment in the Issue from someone saying that they will add that song, choose something else to add.
  1. Fork this repository. This will create a copy of the repository and create a new repository on your account.
  2. Once the repo is forked, you will be taken to the forked repo.
  3. Download the project to your computer. Click on the Clone or Download button. Copy the HTTPS github repo link.
  4. In your terminal, navigate to where you would like to save the project (such as cd Desktop). Run the following command in the terminal, replacing the following link with your copied link: git clone https://github.com/your-username-will-be-here/emojibops.git;
  5. After the command has been run, in the terminal, navigate into the EmojiBops project folder: cd emojibops.
  6. Open the emojibops project in your text editor of choice. Edit the data.js file by clicking on the pencil icon and add a new object for your song in alphabetical order. Note: If the song title starts with 'The' then use the next word for alphabetical order. Make sure there is a comma between your object and the object above and below. Refer to the card overview above for requirements for the different object keys. Make sure to save your file after you have made changes.

Use the following object as a template:

{
  title: "Old Town Road",
  artist: ["Lil Nas X"],
  featuredArtist: ["Billy Ray Cyrus"],
  emojiImgs: "πŸŽπŸ›£οΈπŸŽΈπŸ€ ",
  musicVideo: "https://www.youtube.com/watch?v=w2Ov5jzm3j8",
  genres: ["hip-hop", "country"],
  year: 2019
}
  1. If you would like to see what your addition will look like, open the index.html file that is in the emojibops folder in a web browser. The EmojiCards are added in a random order so it may take you a few seconds to find what you added. If you do not see any cards in the browser, this could mean that you have a typo in your data.js file. If that is the case, double check what you have added for missing commas and quotation marks.
  2. Once you are done, go to the terminal and type git status. You should see data.js as modified. If you don't see this, go back and make sure to save your data.js file.
  3. Run git add -A to add your changes.
  4. Add a commit message. Run the following command and replace with your song name: git commit -m "Added Wannabe by Spice Girls".
  5. If you have never used git on your computer before, you will see a message asking for you to set your email and username. If you do not see that message, continue to the next step. Run the following commands, replacing "you@example.com" with your Github email and "Your name" with your github username:

git config --global user.email "you@example.com"

git config --global user.name "Your Name"

Then re-run the commit command. Remember to replace with your song: git commit -m "Added Wannabe by Spice Girls"

  1. Run git push. If you have not done this before, git push will not run until you login to your Github account. Type in your Github username and password. NOTE: When you type your password, it will not show in the terminal. Press enter after you type your password to continue.

  2. Go to the Github website and navigate to the Pull Request tab. Click on New Pull Request.

Screenshot of a Pull Request on the Github website

  1. Review your changes and then click Create Pull Request. Add any additional comments, go through the checklist within the Pull Request and add an Issue number if applicable, then click on Create Pull Request.
  2. Wait for feedback/review of your Pull Request. Your code will be reviewed and if any changes need to be made, we will let you know. Once your pull request is accepted, you will be able to see your card at https://emojibops.com and you will officially have contributed to the project! πŸŽ‰

Other Resources and Options

Credits

πŸ’–Check out a list of all of the EmojiBops contributors.

Emoji graphics are by Twitter and are licensed under CC-BY 4.0. Review the Attribution Requirements for more information.

Please note that this project is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms.