Emojit allows you to rate any web page using emojis 🤯
This repository holds the public code for Emojit.
You can install our extension in various browsers:
Want the bleeding edge latest build? You can install an artifact from a build here. The build reports checksums in the "Extension: Build" step.
Embed the Emojit widget in your site and let users react to the page:
<iframe src="https://emojit.site" title="Emojit reaction picker"
referrerpolicy="unsafe-url"
width="400px" height="500px" style="border:none;">
</iframe>
referrerpolicy="unsafe-url"
allows the code in the iframe to get the referring URL.
If someone has security concerns, then create an issue on GitHub and we can discuss other options.
There are a bunch of suggestions at https://stackoverflow.com/questions/3420004, but we shouldn't do something that passes the full URL as a URL parameter to the iframe since that's not secure because someone could easily fake it.
Maybe we could use postMessage
and verify the origin.
See the code for our browser extension.
Core Code including the API client.
To install our package, you will need to authenticate with GitHub Packages:
npm login --scope=@emogit --registry=https://npm.pkg.github.com
Install the package:
npm install @emogit/emojit-core
or
yarn add @emogit/emojit-core
Examples:
import { createNewUserId, EmojitClient, ReactionModification, ReactRequest } from '@emogit/emojit-core'
// Create a client for a specific user.
// A userId is a v4 UUID. It should be kept secret.
const userId = createNewUserId()
const client = new EmojitClient(userId)
// Add a reaction to a page.
const url = 'https://mysite.site/page'
const reactResponse = await client.react(new ReactRequest(
url,
[
new ReactionModification('💕', 1),
new ReactionModification('🤓', 1),
]))
// reactResponse has the user's current reactions for the URL:
// { reactions: ['💕', '🤓'] }
// Check the reactions on a page.
const pageReactions = await client.getPageReactions(url)
// pageReactions has the reactions for all users for the URL:
// { reactions: [{ reaction: '👨💻', count: 3 }, { reaction: '💕', count: 2 }, { reaction: '🤓', count: 1 }, ...]}
See client.ts for full details.
Use Node 16 because Node 18 has issues with webpack 4.
Some helpful commands from the root:
- Install all subprojects:
./scripts/run-all.sh yarn install
- Lint all:
./scripts/run-all.sh yarn lint
- Lint
--fix
all:./scripts/run-all.sh yarn lint-fix
- Test all:
./scripts/run-all.sh yarn test