Add option to use twemojis instead of emojis (#121)

This commit is contained in:
Simon Lecoq
2021-02-10 19:57:01 +01:00
committed by GitHub
parent 4ba1e46fb3
commit 7f83f78dcf
9 changed files with 60 additions and 0 deletions

View File

@@ -55,6 +55,8 @@
//Rendering and resizing
console.debug(`metrics/compute/${login} > render`)
let rendered = await ejs.render(image, {...data, s:imports.s, f:imports.format, style, fonts}, {views, async:true})
if (q["config.twemoji"])
rendered = await imports.svgemojis(rendered)
const {resized, mime} = await imports.svgresize(rendered, {paddings:q["config.padding"] || conf.settings.padding, convert})
rendered = resized

View File

@@ -9,6 +9,7 @@
import puppeteer from "puppeteer"
import imgb64 from "image-to-base64"
import git from "simple-git"
import twemojis from "twemoji-parser"
export {fs, os, paths, url, util, processes, axios, puppeteer, imgb64, git}
@@ -168,6 +169,20 @@
return {resized, mime}
}
/**Render twemojis */
export async function svgemojis(svg) {
//Load emojis
const emojis = new Map()
for (const {text:emoji, url} of twemojis.parse(svg)) {
if (!emojis.has(emoji))
emojis.set(emoji, (await axios.get(url)).data.replace(/^<svg /, '<svg class="twemoji" '))
}
//Apply replacements
for (const [emoji, twemoji] of emojis)
svg = svg.replace(new RegExp(emoji, "g"), twemoji)
return svg
}
/**Wait */
export async function wait(seconds) {
await new Promise(solve => setTimeout(solve, seconds*1000)) //eslint-disable-line no-promise-executor-return

View File

@@ -39,6 +39,21 @@ Omitted one will be appended using default order.
config_order: base.header, isocalendar, languages, stars
```
### 🙂 Using twemojis instead of emojis
You can choose to use [twemojis](https://github.com/twitter/twemoji) instead of regular emojis so rendered metrics are more consistent across all platforms.
It may increase filesize since it replace unicode characters by SVG images.
#### Examples workflows
```yaml
- uses: lowlighter/metrics@latest
with:
# ... other options
config_twemoji: yes
```
### 🎞️ SVG CSS Animations
As rendered metrics use HTML and CSS, some templates have animations.

View File

@@ -88,6 +88,13 @@ inputs:
format: comma-separated
default: ""
# Use twemojis instead of emojis
# May increase filesize but emojis will be rendered the same across all platforms
config_twemoji:
description: Use twemojis instead of emojis
type: boolean
default: no
# Enable SVG CSS animations
config_animations:
description: SVG CSS animations

View File

@@ -10,6 +10,12 @@
token: MOCKED_TOKEN
config_output: png
- name: Use twemoji
uses: lowlighter/metrics@latest
with:
token: MOCKED_TOKEN
config_twemoji: yes
- name: Disable animations
uses: lowlighter/metrics@latest
with:

View File

@@ -649,6 +649,13 @@
}
}
/* Twemoji */
.twemoji {
height: 1em;
width: 1em;
margin-bottom: -.125em;
}
/* Cake day */
.cakeday, .cakeday svg {
animation: animation-rainbow 1.2s;