Need a card for a gender reveal party? Emoji Gender Reveal has you covered with the latest in emoji gender technology! Just click the card to randomly pick a new emoji gender!
Play with it live on Glitch 🎏
Click on the title card to generate a new random emoji gender reveal.
Not all emoji are permitted on this app:
- Emoji that reference oppressive structures (such as POLICE OFFICER or CUSTOMS) are not allowed.
- Emoji that are too close to a real gender reveal (such as BOY or WOMAN) aren't funny and thus are not allowed.
These restrictions are defined in the emojiFilter()
function in src/emojifuncs.js
. If you find additional emoji that should not be used according to those criteria, submit an issue on GitHub with your reasoning, and it will be considered.
Root directory
The Express routing server, the origin of all the behavior of this app. Defines 3 routes:
- A main route
/
which returns the main app page. - An emoji route
/emoji
which returns a random emoji (saves the browser from having to download the whole list at the beginning). - A puppeteer route
/puppeteer
which returns a simplified app page suitable for automated retrieval.
Environment variable definition file.
This folder contains the code and assets that will get packaged by Rollup for delivery to the user's browser.
The client.*
files are files that are used to build the main page of the web app that users will see.
The puppeteer.*
files are files that are used to build the page of the web app that a headless puppeteer
instance of Chromium will use to retrieve the generated emoji image.
This file contains all the functions that draw an image onto a <canvas>
context
This file contains miscellaneous helper functions for other files to import when needed.
These Node.js scripts are where the automation code lives. They are not inluded in Rollup.
This file contains the functions necessary to automatically extract the generated emoji gender reveal image and associated metadata from the puppeteer route.
Node.js and other scripts and files related to processing emoji.
This file contains helper functions focused on manipulating lists of emoji.
A Python script used for creating a JSON file of all fully-qualified emoji from the Unicode 13.0 emoji-test.txt file.
This file is a JSON array of all the fully-qualified emoji from Unicode 13.0 and is the source of the emoji code points and descriptions that this app uses.
[
[
"\ud83d\ude00",
{
"char": "\ud83d\ude00",
"descr": "grinning face"
}
],
...
]
It is an array of key-value pairs, with the key being the string of the emoji, and the value being an object with the properties char
(Unicode string of the emoji) and descr
(the emoji's official description in lower-case). This file is generated using the emoji_libs/emoji_test_extractor.py
script from Unicode's emoji-test.txt file.
git clone https://github.com/noelleleigh/emoji-gender-reveal.git
cd emoji-gender-reveal
Specify the port you want it to run on in an .env
file. Example:
PORT=8080
Then run
npm install
npm start
Once the build is complete and the server has started, open http://localhost:8080 (replace 8080
with whatever port you chose).
- Add support for HTTP authentication on the bot endpoint.
- Extract out the disallowed emoji list to make it easily editable.
- Add loading indicators for slow connections.
- Improve experience on screen readers.