Porównaj commity

...

12 Commity

Autor SHA1 Wiadomość Data
Amio a303e46dad 3.2.3 2023-07-21 20:04:46 +08:00
Amio Jin 23108a625f
fix: generate random id for svg elements. Fixes #71 (#78) 2023-06-22 15:36:02 +08:00
dependabot[bot] 25ee3bd4bd
build(deps): bump json5 from 2.2.1 to 2.2.3 (#76)
Bumps [json5](https://github.com/json5/json5) from 2.2.1 to 2.2.3.
- [Release notes](https://github.com/json5/json5/releases)
- [Changelog](https://github.com/json5/json5/blob/main/CHANGELOG.md)
- [Commits](https://github.com/json5/json5/compare/v2.2.1...v2.2.3)

---
updated-dependencies:
- dependency-name: json5
  dependency-type: indirect
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2023-02-24 18:33:45 +08:00
简静凡 665dc507ee
feat: export typescript types (#77)
- export type StyleOption
- export type ColorPreset
- export type BadgenOptions
2023-02-24 18:33:13 +08:00
Amio fdfe99c051 fix: correctly render undefined label 2022-04-30 17:31:10 +08:00
Amio 2ca1ce4755 chore: disable coverage check in tap 2022-04-30 17:14:20 +08:00
Amio 609f95c21a chore: remove test for nodejs 8 and 10 2022-04-30 17:14:20 +08:00
Amio 18f79c98b8 chore: bump esbuild to 0.14, tap to 16 2022-04-30 17:14:20 +08:00
Amio 49b999f5da chore: update tsconfig 2022-04-30 17:14:20 +08:00
Amio ef2f2914d8 chore: npm update 2022-04-30 17:14:20 +08:00
Andrew Patton ab4c32e145
docs: fix in-browser code sample (#72) 2022-04-30 15:54:32 +08:00
chris48s df6c6f026d
feat: apply escaping to all string inputs (#68) 2021-03-28 11:25:47 +08:00
14 zmienionych plików z 4624 dodań i 3604 usunięć

Wyświetl plik

@ -7,7 +7,7 @@ jobs:
strategy:
matrix:
node: [8, 10, 12]
node: [12, 14, 16, 18]
os: [ubuntu-latest]
runs-on: ${{ matrix.os }}

Wyświetl plik

@ -49,7 +49,7 @@ Available color names:
```html
<script src="https://unpkg.com/badgen"></script>
<script>
var svgString = badgen.badgen({ /*...*/ })
var svgString = badgen({ /*...*/ })
</script>
```

7792
package-lock.json wygenerowano

Plik diff jest za duży Load Diff

Wyświetl plik

@ -1,6 +1,6 @@
{
"name": "badgen",
"version": "3.2.2",
"version": "3.2.3",
"description": "Fast svg badge generator.",
"repository": "amio/badgen",
"author": "Amio <amio.cn@gmail.com>",
@ -13,7 +13,7 @@
"preview": "node preview/serve.js",
"snaptests": "TAP_SNAPSHOT=1 npm test",
"pretest": "npm run build",
"test": "tap test/*.spec.ts",
"test": "tap --no-check-coverage",
"prebuild": "rm -rf dist",
"esbuild": "esbuild src/index.ts --bundle --minify --sourcemap",
"build:types": "tsc --emitDeclarationOnly",
@ -26,9 +26,9 @@
"devDependencies": {
"@types/node": "^14.0.14",
"benchmark": "^2.1.4",
"esbuild": "^0.8.17",
"esbuild": "^0.14.38",
"serve-marked": "^3.1.0",
"tap": "^14.10.7",
"tap": "^16.1.0",
"typescript": "^4.1.2"
}
}

Wyświetl plik

@ -1,8 +1,8 @@
// import widthsVerdana110 from './widths-verdana-110.json'
// @ts-ignore
const widthsVerdana110 = require('./widths-verdana-110.json')
const widthsVerdana110: number[] = require('./widths-verdana-110.json')
const calcWidth = (charWidthTable) => {
const calcWidth = (charWidthTable: number[]) => {
const fallbackWidth = charWidthTable[64] // Width as "@" for overflows
return ([...text]) => {

Wyświetl plik

@ -10,4 +10,4 @@ export default {
gray: '999',
cyan: '1BC',
black: '2A2A2A'
}
} as Record<string, string>

Wyświetl plik

@ -2,12 +2,13 @@ export { Verdana110 as calcWidth } from './calc-text-width'
import { Verdana110 as calcWidth } from './calc-text-width'
import colorPresets from './color-presets'
type StyleOption = 'flat' | 'classic'
export type StyleOption = 'flat' | 'classic'
export type ColorPreset = keyof typeof colorPresets
interface BadgenOptions {
export interface BadgenOptions {
status: string;
subject?: string;
color?: string;
color?: ColorPreset;
label?: string;
labelColor?: string
style?: StyleOption;
@ -38,17 +39,23 @@ export function badgen ({
labelColor = colorPresets[labelColor] || labelColor
iconWidth = iconWidth * 10
const iconSpanWidth = icon ? (label.length ? iconWidth + 30 : iconWidth - 18) : 0
const iconSpanWidth = icon ? (label?.length ? iconWidth + 30 : iconWidth - 18) : 0
const sbTextStart = icon ? (iconSpanWidth + 50) : 50
const sbTextWidth = calcWidth(label)
const sbTextWidth = label ? calcWidth(label) : 0
const stTextWidth = calcWidth(status)
const sbRectWidth = sbTextWidth + 100 + iconSpanWidth
const stRectWidth = stTextWidth + 100
const width = sbRectWidth + stRectWidth
const xlink = icon ? ' xmlns:xlink="http://www.w3.org/1999/xlink"' : ''
label = sanitize(label)
const gradientId = generateRandomID(5)
const maskId = generateRandomID(5)
label = label ? sanitize(label) : ''
status = sanitize(status)
color = sanitize(color)
labelColor = sanitize(labelColor)
icon = icon ? sanitize(icon) : icon
const accessibleText = createAccessibleText({label, status})
if (style === 'flat') {
@ -70,15 +77,15 @@ export function badgen ({
return `<svg width="${scale * width / 10}" height="${scale * 20}" viewBox="0 0 ${width} 200" xmlns="http://www.w3.org/2000/svg"${xlink} role="img" aria-label="${accessibleText}">
<title>${accessibleText}</title>
<linearGradient id="a" x2="0" y2="100%">
<linearGradient id="${gradientId}" x2="0" y2="100%">
<stop offset="0" stop-opacity=".1" stop-color="#EEE"/>
<stop offset="1" stop-opacity=".1"/>
</linearGradient>
<mask id="m"><rect width="${width}" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#m)">
<mask id="${maskId}"><rect width="${width}" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#${maskId})">
<rect width="${sbRectWidth}" height="200" fill="#${labelColor}"/>
<rect width="${stRectWidth}" height="200" fill="#${color}" x="${sbRectWidth}"/>
<rect width="${width}" height="200" fill="url(#a)"/>
<rect width="${width}" height="200" fill="url(#${gradientId})"/>
</g>
<g aria-hidden="true" fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="${sbTextStart + 10}" y="148" textLength="${sbTextWidth}" fill="#000" opacity="0.25">${label}</text>
@ -90,14 +97,18 @@ export function badgen ({
</svg>`
}
function bare ({ status, color, style, scale }) {
function bare ({ status, color = 'blue', style, scale = 1 }: BadgenOptions) {
typeAssert(typeof status === 'string', '<status> must be string')
color = colorPresets[color] || color || colorPresets.blue
const stTextWidth = calcWidth(status)
const stRectWidth = stTextWidth + 115
const gradientId = generateRandomID(5)
const maskId = generateRandomID(5)
status = sanitize(status)
color = sanitize(color)
if (style === 'flat') {
return `<svg width="${scale * stRectWidth / 10}" height="${scale * 20}" viewBox="0 0 ${stRectWidth} 200" xmlns="http://www.w3.org/2000/svg" role="img" aria-label="${status}">
@ -114,14 +125,14 @@ function bare ({ status, color, style, scale }) {
return `<svg width="${scale * stRectWidth / 10}" height="${scale * 20}" viewBox="0 0 ${stRectWidth} 200" xmlns="http://www.w3.org/2000/svg" role="img" aria-label="${status}">
<title>${status}</title>
<linearGradient id="a" x2="0" y2="100%">
<linearGradient id="${gradientId}" x2="0" y2="100%">
<stop offset="0" stop-opacity=".1" stop-color="#EEE"/>
<stop offset="1" stop-opacity=".1"/>
</linearGradient>
<mask id="m"><rect width="${stRectWidth}" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#m)">
<mask id="${maskId}"><rect width="${stRectWidth}" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#${maskId})">
<rect width="${stRectWidth}" height="200" fill="#${color}" x="0"/>
<rect width="${stRectWidth}" height="200" fill="url(#a)"/>
<rect width="${stRectWidth}" height="200" fill="url(#${gradientId})"/>
</g>
<g aria-hidden="true" fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="65" y="148" textLength="${stTextWidth}" fill="#000" opacity="0.25">${status}</text>
@ -144,6 +155,17 @@ interface AccessibleTextProps {
label?: string;
}
function generateRandomID(length: number): string {
const characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz';
let result = '';
for (let i = 0; i < length; i++) {
result += characters.charAt(Math.floor(Math.random() * characters.length));
}
return result;
}
function createAccessibleText({label, status}: AccessibleTextProps): string {
const labelPrefix = label ? `${label}: ` : '';
return labelPrefix + status;

Wyświetl plik

@ -5,6 +5,48 @@
* Make sure to inspect the output below. Do not ignore changes!
*/
'use strict'
exports[`test/badgen.spec.ts TAP ensure badgen() correctly escapes string inputs > snapshot 1`] = `
<svg width="191.2" height="20" viewBox="0 0 1912 200" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" role="img" aria-label="&lt;escape me&gt;: &lt;escape me&gt;">
<title>&lt;escape me&gt;: &lt;escape me&gt;</title>
<linearGradient id="a" x2="0" y2="100%">
<stop offset="0" stop-opacity=".1" stop-color="#EEE"/>
<stop offset="1" stop-opacity=".1"/>
</linearGradient>
<mask id="m"><rect width="1912" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#m)">
<rect width="1036" height="200" fill="#&lt;escape me&gt;"/>
<rect width="876" height="200" fill="#&lt;escape me&gt;" x="1036"/>
<rect width="1912" height="200" fill="url(#a)"/>
</g>
<g aria-hidden="true" fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="220" y="148" textLength="776" fill="#000" opacity="0.25">&lt;escape me&gt;</text>
<text x="210" y="138" textLength="776">&lt;escape me&gt;</text>
<text x="1091" y="148" textLength="776" fill="#000" opacity="0.25">&lt;escape me&gt;</text>
<text x="1081" y="138" textLength="776">&lt;escape me&gt;</text>
</g>
<image x="40" y="35" width="130" height="130" xlink:href="&lt;escape me&gt;"/>
</svg>
`
exports[`test/badgen.spec.ts TAP ensure bare() correctly escapes string inputs > snapshot 1`] = `
<svg width="89.1" height="20" viewBox="0 0 891 200" xmlns="http://www.w3.org/2000/svg" role="img" aria-label="&lt;escape me&gt;">
<title>&lt;escape me&gt;</title>
<linearGradient id="a" x2="0" y2="100%">
<stop offset="0" stop-opacity=".1" stop-color="#EEE"/>
<stop offset="1" stop-opacity=".1"/>
</linearGradient>
<mask id="m"><rect width="891" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#m)">
<rect width="891" height="200" fill="#&lt;escape me&gt;" x="0"/>
<rect width="891" height="200" fill="url(#a)"/>
</g>
<g aria-hidden="true" fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="65" y="148" textLength="776" fill="#000" opacity="0.25">&lt;escape me&gt;</text>
<text x="55" y="138" textLength="776">&lt;escape me&gt;</text>
</g>
</svg>
`
exports[`test/badgen.spec.ts TAP generate badge with { label, status } > snapshot 1`] = `
<svg width="80.4" height="20" viewBox="0 0 804 200" xmlns="http://www.w3.org/2000/svg" role="img" aria-label="npm: v1.0.0">
<title>npm: v1.0.0</title>

Wyświetl plik

@ -5,18 +5,18 @@
* Make sure to inspect the output below. Do not ignore changes!
*/
'use strict'
exports[`test/calc-width.spec.js TAP calc width for "npm" > result is correct 1`] = `
exports[`test/calc-width.spec.ts TAP calc width for "npm" > result is correct 1`] = `
249
`
exports[`test/calc-width.spec.js TAP calc width for emojis > result is correct 1`] = `
exports[`test/calc-width.spec.ts TAP calc width for emojis > result is correct 1`] = `
330
`
exports[`test/calc-width.spec.js TAP calc width for special chars > result is correct 1`] = `
exports[`test/calc-width.spec.ts TAP calc width for special chars > result is correct 1`] = `
600
`
exports[`test/calc-width.spec.js TAP calc width for unicode > result is correct 1`] = `
exports[`test/calc-width.spec.ts TAP calc width for unicode > result is correct 1`] = `
550
`

Wyświetl plik

@ -0,0 +1,265 @@
/* IMPORTANT
* This snapshot file is auto-generated, but designed for humans.
* It should be checked into source control and tracked carefully.
* Re-generate by setting TAP_SNAPSHOT=1 and running tests.
* Make sure to inspect the output below. Do not ignore changes!
*/
'use strict'
exports[`test/badgen.spec.js TAP ensure badgen() correctly escapes string inputs > snapshot 1`] = `
<svg width="191.2" height="20" viewBox="0 0 1912 200" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" role="img" aria-label="&lt;escape me&gt;: &lt;escape me&gt;">
<title>&lt;escape me&gt;: &lt;escape me&gt;</title>
<linearGradient id="aaaaa" x2="0" y2="100%">
<stop offset="0" stop-opacity=".1" stop-color="#EEE"/>
<stop offset="1" stop-opacity=".1"/>
</linearGradient>
<mask id="aaaaa"><rect width="1912" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#aaaaa)">
<rect width="1036" height="200" fill="#&lt;escape me&gt;"/>
<rect width="876" height="200" fill="#&lt;escape me&gt;" x="1036"/>
<rect width="1912" height="200" fill="url(#aaaaa)"/>
</g>
<g aria-hidden="true" fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="220" y="148" textLength="776" fill="#000" opacity="0.25">&lt;escape me&gt;</text>
<text x="210" y="138" textLength="776">&lt;escape me&gt;</text>
<text x="1091" y="148" textLength="776" fill="#000" opacity="0.25">&lt;escape me&gt;</text>
<text x="1081" y="138" textLength="776">&lt;escape me&gt;</text>
</g>
<image x="40" y="35" width="130" height="130" xlink:href="&lt;escape me&gt;"/>
</svg>
`
exports[`test/badgen.spec.js TAP ensure bare() correctly escapes string inputs > snapshot 1`] = `
<svg width="89.1" height="20" viewBox="0 0 891 200" xmlns="http://www.w3.org/2000/svg" role="img" aria-label="&lt;escape me&gt;">
<title>&lt;escape me&gt;</title>
<linearGradient id="aaaaa" x2="0" y2="100%">
<stop offset="0" stop-opacity=".1" stop-color="#EEE"/>
<stop offset="1" stop-opacity=".1"/>
</linearGradient>
<mask id="aaaaa"><rect width="891" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#aaaaa)">
<rect width="891" height="200" fill="#&lt;escape me&gt;" x="0"/>
<rect width="891" height="200" fill="url(#aaaaa)"/>
</g>
<g aria-hidden="true" fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="65" y="148" textLength="776" fill="#000" opacity="0.25">&lt;escape me&gt;</text>
<text x="55" y="138" textLength="776">&lt;escape me&gt;</text>
</g>
</svg>
`
exports[`test/badgen.spec.js TAP generate badge with { label, status } > snapshot 1`] = `
<svg width="80.4" height="20" viewBox="0 0 804 200" xmlns="http://www.w3.org/2000/svg" role="img" aria-label="npm: v1.0.0">
<title>npm: v1.0.0</title>
<linearGradient id="aaaaa" x2="0" y2="100%">
<stop offset="0" stop-opacity=".1" stop-color="#EEE"/>
<stop offset="1" stop-opacity=".1"/>
</linearGradient>
<mask id="aaaaa"><rect width="804" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#aaaaa)">
<rect width="349" height="200" fill="#555"/>
<rect width="455" height="200" fill="#08C" x="349"/>
<rect width="804" height="200" fill="url(#aaaaa)"/>
</g>
<g aria-hidden="true" fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="60" y="148" textLength="249" fill="#000" opacity="0.25">npm</text>
<text x="50" y="138" textLength="249">npm</text>
<text x="404" y="148" textLength="355" fill="#000" opacity="0.25">v1.0.0</text>
<text x="394" y="138" textLength="355">v1.0.0</text>
</g>
</svg>
`
exports[`test/badgen.spec.js TAP generate badge with { label, status, color } > snapshot 1`] = `
<svg width="80.4" height="20" viewBox="0 0 804 200" xmlns="http://www.w3.org/2000/svg" role="img" aria-label="npm: v1.0.0">
<title>npm: v1.0.0</title>
<linearGradient id="aaaaa" x2="0" y2="100%">
<stop offset="0" stop-opacity=".1" stop-color="#EEE"/>
<stop offset="1" stop-opacity=".1"/>
</linearGradient>
<mask id="aaaaa"><rect width="804" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#aaaaa)">
<rect width="349" height="200" fill="#555"/>
<rect width="455" height="200" fill="#ADF" x="349"/>
<rect width="804" height="200" fill="url(#aaaaa)"/>
</g>
<g aria-hidden="true" fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="60" y="148" textLength="249" fill="#000" opacity="0.25">npm</text>
<text x="50" y="138" textLength="249">npm</text>
<text x="404" y="148" textLength="355" fill="#000" opacity="0.25">v1.0.0</text>
<text x="394" y="138" textLength="355">v1.0.0</text>
</g>
</svg>
`
exports[`test/badgen.spec.js TAP generate badge with { label, status, color, style } > snapshot 1`] = `
<svg width="80.4" height="20" viewBox="0 0 804 200" xmlns="http://www.w3.org/2000/svg" role="img" aria-label="npm: v1.0.0">
<title>npm: v1.0.0</title>
<g>
<rect fill="#555" width="349" height="200"/>
<rect fill="#ADF" x="349" width="455" height="200"/>
</g>
<g aria-hidden="true" fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="60" y="148" textLength="249" fill="#000" opacity="0.1">npm</text>
<text x="50" y="138" textLength="249">npm</text>
<text x="404" y="148" textLength="355" fill="#000" opacity="0.1">v1.0.0</text>
<text x="394" y="138" textLength="355">v1.0.0</text>
</g>
</svg>
`
exports[`test/badgen.spec.js TAP generate badge with { label, status, icon } > snapshot 1`] = `
<svg width="95.5" height="20" viewBox="0 0 955 200" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" role="img" aria-label="docker: icon">
<title>docker: icon</title>
<linearGradient id="aaaaa" x2="0" y2="100%">
<stop offset="0" stop-opacity=".1" stop-color="#EEE"/>
<stop offset="1" stop-opacity=".1"/>
</linearGradient>
<mask id="aaaaa"><rect width="955" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#aaaaa)">
<rect width="631" height="200" fill="#555"/>
<rect width="324" height="200" fill="#08C" x="631"/>
<rect width="955" height="200" fill="url(#aaaaa)"/>
</g>
<g aria-hidden="true" fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="220" y="148" textLength="371" fill="#000" opacity="0.25">docker</text>
<text x="210" y="138" textLength="371">docker</text>
<text x="686" y="148" textLength="224" fill="#000" opacity="0.25">icon</text>
<text x="676" y="138" textLength="224">icon</text>
</g>
<image x="40" y="35" width="130" height="130" xlink:href=""/>
</svg>
`
exports[`test/badgen.spec.js TAP generate badge with { label, status, icon, style } > snapshot 1`] = `
<svg width="95.5" height="20" viewBox="0 0 955 200" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" role="img" aria-label="docker: icon">
<title>docker: icon</title>
<g>
<rect fill="#555" width="631" height="200"/>
<rect fill="#08C" x="631" width="324" height="200"/>
</g>
<g aria-hidden="true" fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="220" y="148" textLength="371" fill="#000" opacity="0.1">docker</text>
<text x="210" y="138" textLength="371">docker</text>
<text x="686" y="148" textLength="224" fill="#000" opacity="0.1">icon</text>
<text x="676" y="138" textLength="224">icon</text>
</g>
<image x="40" y="35" width="130" height="132" xlink:href=""/>
</svg>
`
exports[`test/badgen.spec.js TAP generate badge with { label, status, style } > snapshot 1`] = `
<svg width="80.4" height="20" viewBox="0 0 804 200" xmlns="http://www.w3.org/2000/svg" role="img" aria-label="npm: v1.0.0">
<title>npm: v1.0.0</title>
<g>
<rect fill="#555" width="349" height="200"/>
<rect fill="#08C" x="349" width="455" height="200"/>
</g>
<g aria-hidden="true" fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="60" y="148" textLength="249" fill="#000" opacity="0.1">npm</text>
<text x="50" y="138" textLength="249">npm</text>
<text x="404" y="148" textLength="355" fill="#000" opacity="0.1">v1.0.0</text>
<text x="394" y="138" textLength="355">v1.0.0</text>
</g>
</svg>
`
exports[`test/badgen.spec.js TAP generate badge with { status, icon } > snapshot 1`] = `
<svg width="53.6" height="20" viewBox="0 0 536 200" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" role="img" aria-label="icon">
<title>icon</title>
<linearGradient id="aaaaa" x2="0" y2="100%">
<stop offset="0" stop-opacity=".1" stop-color="#EEE"/>
<stop offset="1" stop-opacity=".1"/>
</linearGradient>
<mask id="aaaaa"><rect width="536" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#aaaaa)">
<rect width="212" height="200" fill="#555"/>
<rect width="324" height="200" fill="#08C" x="212"/>
<rect width="536" height="200" fill="url(#aaaaa)"/>
</g>
<g aria-hidden="true" fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="172" y="148" textLength="0" fill="#000" opacity="0.25"></text>
<text x="162" y="138" textLength="0"></text>
<text x="267" y="148" textLength="224" fill="#000" opacity="0.25">icon</text>
<text x="257" y="138" textLength="224">icon</text>
</g>
<image x="40" y="35" width="130" height="130" xlink:href=""/>
</svg>
`
exports[`test/badgen.spec.js TAP generate badge with { status, icon, iconWidth } > snapshot 1`] = `
<svg width="59.6" height="20" viewBox="0 0 596 200" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" role="img" aria-label="icon">
<title>icon</title>
<linearGradient id="aaaaa" x2="0" y2="100%">
<stop offset="0" stop-opacity=".1" stop-color="#EEE"/>
<stop offset="1" stop-opacity=".1"/>
</linearGradient>
<mask id="aaaaa"><rect width="596" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#aaaaa)">
<rect width="272" height="200" fill="#555"/>
<rect width="324" height="200" fill="#08C" x="272"/>
<rect width="596" height="200" fill="url(#aaaaa)"/>
</g>
<g aria-hidden="true" fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="232" y="148" textLength="0" fill="#000" opacity="0.25"></text>
<text x="222" y="138" textLength="0"></text>
<text x="327" y="148" textLength="224" fill="#000" opacity="0.25">icon</text>
<text x="317" y="138" textLength="224">icon</text>
</g>
<image x="40" y="35" width="190" height="130" xlink:href=""/>
</svg>
`
exports[`test/badgen.spec.js TAP generate bare badge with { status } > snapshot 1`] = `
<svg width="47" height="20" viewBox="0 0 470 200" xmlns="http://www.w3.org/2000/svg" role="img" aria-label="v1.0.0">
<title>v1.0.0</title>
<linearGradient id="aaaaa" x2="0" y2="100%">
<stop offset="0" stop-opacity=".1" stop-color="#EEE"/>
<stop offset="1" stop-opacity=".1"/>
</linearGradient>
<mask id="aaaaa"><rect width="470" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#aaaaa)">
<rect width="470" height="200" fill="#08C" x="0"/>
<rect width="470" height="200" fill="url(#aaaaa)"/>
</g>
<g aria-hidden="true" fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="65" y="148" textLength="355" fill="#000" opacity="0.25">v1.0.0</text>
<text x="55" y="138" textLength="355">v1.0.0</text>
</g>
</svg>
`
exports[`test/badgen.spec.js TAP generate bare badge with { status, color } > snapshot 1`] = `
<svg width="47" height="20" viewBox="0 0 470 200" xmlns="http://www.w3.org/2000/svg" role="img" aria-label="v1.0.0">
<title>v1.0.0</title>
<linearGradient id="aaaaa" x2="0" y2="100%">
<stop offset="0" stop-opacity=".1" stop-color="#EEE"/>
<stop offset="1" stop-opacity=".1"/>
</linearGradient>
<mask id="aaaaa"><rect width="470" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#aaaaa)">
<rect width="470" height="200" fill="#ADF" x="0"/>
<rect width="470" height="200" fill="url(#aaaaa)"/>
</g>
<g aria-hidden="true" fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="65" y="148" textLength="355" fill="#000" opacity="0.25">v1.0.0</text>
<text x="55" y="138" textLength="355">v1.0.0</text>
</g>
</svg>
`
exports[`test/badgen.spec.js TAP generate bare badge with { status, style } > snapshot 1`] = `
<svg width="47" height="20" viewBox="0 0 470 200" xmlns="http://www.w3.org/2000/svg" role="img" aria-label="v1.0.0">
<title>v1.0.0</title>
<g>
<rect fill="#08C" x="0" width="470" height="200"/>
</g>
<g aria-hidden="true" fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="65" y="148" textLength="355" fill="#000" opacity="0.1">v1.0.0</text>
<text x="55" y="138" textLength="355">v1.0.0</text>
</g>
</svg>
`

Wyświetl plik

@ -5,18 +5,18 @@
* Make sure to inspect the output below. Do not ignore changes!
*/
'use strict'
exports[`test/calc-width.spec.ts TAP calc width for "npm" > result is correct 1`] = `
exports[`test/calc-width.spec.js TAP calc width for "npm" > result is correct 1`] = `
249
`
exports[`test/calc-width.spec.ts TAP calc width for emojis > result is correct 1`] = `
exports[`test/calc-width.spec.js TAP calc width for emojis > result is correct 1`] = `
330
`
exports[`test/calc-width.spec.ts TAP calc width for special chars > result is correct 1`] = `
exports[`test/calc-width.spec.js TAP calc width for special chars > result is correct 1`] = `
600
`
exports[`test/calc-width.spec.ts TAP calc width for unicode > result is correct 1`] = `
exports[`test/calc-width.spec.js TAP calc width for unicode > result is correct 1`] = `
550
`

Wyświetl plik

@ -1,6 +1,13 @@
import tap from 'tap'
import { badgen } from '../dist'
import * as icons from './assets/icon-data-uri.js'
const tap = require('tap')
const { badgen } = require('../dist')
const icons = require('./assets/icon-data-uri.js')
const originalMath = global.Math
const mockMath = Object.create(global.Math)
mockMath.random = () => 0.5
tap.beforeEach(async t => { global.Math = mockMath })
tap.afterEach(async t => { global.Math = originalMath })
tap.test('generate badge with { label, status }', t => {
const svg = badgen({ label: 'npm', status: 'v1.0.0' })
@ -54,6 +61,18 @@ tap.test('generate badge with { label, status, icon, style }', t => {
t.end()
})
tap.test('ensure badgen() correctly escapes string inputs', t => {
const svg = badgen({
label: '<escape me>',
status: '<escape me>',
color: '<escape me>',
icon: '<escape me>',
labelColor: '<escape me>',
})
t.matchSnapshot(svg, 'snapshot')
t.end()
})
tap.test('generate bare badge with { status }', t => {
const svg = badgen({ status: 'v1.0.0' })
t.ok(typeof svg === 'string', 'successfully generated')
@ -75,6 +94,15 @@ tap.test('generate bare badge with { status, style }', t => {
t.end()
})
tap.test('ensure bare() correctly escapes string inputs', t => {
const svg = badgen({
status: '<escape me>',
color: '<escape me>',
})
t.matchSnapshot(svg, 'snapshot')
t.end()
})
tap.test('type checking', t => {
// @ts-ignore
t.throws(() => badgen({}), TypeError, 'throw if status is non-string')

Wyświetl plik

@ -1,5 +1,5 @@
import tap from 'tap'
import { calcWidth } from '../dist'
const tap = require('tap')
const { calcWidth } = require('../dist')
tap.test('basic functions', t => {
t.ok(typeof calcWidth === 'function', 'export calcWidth function')

Wyświetl plik

@ -1,5 +1,7 @@
{
"compilerOptions": {
"strict": true,
"target": "es2017",
"module": "commonjs",
"lib": ["esnext", "dom"],
@ -12,7 +14,8 @@
"resolveJsonModule": true,
"experimentalDecorators": true,
"allowSyntheticDefaultImports": true
"allowSyntheticDefaultImports": true,
"forceConsistentCasingInFileNames": true,
},
"include": ["src"]
}