feat(plugins/core): add config_octicon support (#838) [skip ci]

This commit is contained in:
Simon Lecoq
2022-02-04 04:39:11 +01:00
committed by GitHub
parent 9b27024c56
commit cc855ad228
5 changed files with 62 additions and 5 deletions

View File

@@ -157,6 +157,7 @@ export default async function metrics({login, q}, {graphql, rest, plugins, conf,
style:extras.css,
twemojis:q["config.twemoji"],
gemojis:q["config.gemoji"],
octicons:q["config.octicon"],
rest,
})
}
@@ -172,6 +173,8 @@ export default async function metrics({login, q}, {graphql, rest, plugins, conf,
rendered = await imports.svg.twemojis(rendered)
if (q["config.gemoji"])
rendered = await imports.svg.gemojis(rendered, {rest})
if (q["config.octicon"])
rendered = await imports.svg.octicons(rendered)
//Optimize rendering
if ((conf.settings?.optimize === true) || (conf.settings?.optimize?.includes?.("css")))
rendered = await imports.svg.optimize.css(rendered)

View File

@@ -30,7 +30,7 @@ import twemojis from "twemoji-parser"
import url from "url"
import util from "util"
import xmlformat from "xml-formatter"
import octicons from "@primer/octicons"
prism_lang()
//Exports
@@ -367,7 +367,7 @@ export async function imgb64(image, {width, height, fallback = true} = {}) {
/**SVG utils */
export const svg = {
/**Render as pdf */
async pdf(rendered, {paddings = "", style = "", twemojis = false, gemojis = false, rest = null} = {}) {
async pdf(rendered, {paddings = "", style = "", twemojis = false, gemojis = false, octicons = false, rest = null} = {}) {
//Instantiate browser if needed
if (!svg.resize.browser) {
svg.resize.browser = await puppeteer.launch()
@@ -378,6 +378,8 @@ export const svg = {
rendered = await svg.twemojis(rendered, {custom:false})
if ((gemojis) && (rest))
rendered = await svg.gemojis(rendered, {rest})
if (octicons)
rendered = await svg.octicons(rendered)
rendered = marked.parse(rendered)
//Render through browser and print pdf
console.debug("metrics/svg/pdf > loading svg")
@@ -550,6 +552,26 @@ export const svg = {
rendered = rendered.replace(new RegExp(emoji, "g"), gemoji)
return rendered
},
/**Render github octicons */
async octicons(rendered) {
//Load octicons
console.debug("metrics/svg/octicons > rendering octicons")
const icons = new Map()
for (const {name, heights, toSVG} of Object.values(octicons)) {
for (const size of Object.keys(heights)) {
const octicon = `:octicon-${name}-${size}:`
if (new RegExp(`:octicon-${name}(?:-[0-9]+)?:`, "g").test(rendered)) {
icons.set(octicon, toSVG({height:size, width:size}))
if (Number(size) === 16)
icons.set(`:octicon-${name}:`, toSVG({height:size, width:size}))
}
}
}
//Apply replacements
for (const [octicon, image] of icons)
rendered = rendered.replace(new RegExp(octicon, "g"), image)
return rendered
},
/**Optimizers */
optimize:{
/**CSS optimizer */