kopia lustrzana https://github.com/badgen/badgen
Porównaj commity
12 Commity
Autor | SHA1 | Data |
---|---|---|
![]() |
a303e46dad | |
![]() |
23108a625f | |
![]() |
25ee3bd4bd | |
![]() |
665dc507ee | |
![]() |
fdfe99c051 | |
![]() |
2ca1ce4755 | |
![]() |
609f95c21a | |
![]() |
18f79c98b8 | |
![]() |
49b999f5da | |
![]() |
ef2f2914d8 | |
![]() |
ab4c32e145 | |
![]() |
df6c6f026d |
|
@ -7,7 +7,7 @@ jobs:
|
||||||
|
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
node: [8, 10, 12]
|
node: [12, 14, 16, 18]
|
||||||
os: [ubuntu-latest]
|
os: [ubuntu-latest]
|
||||||
|
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
|
|
|
@ -49,7 +49,7 @@ Available color names:
|
||||||
```html
|
```html
|
||||||
<script src="https://unpkg.com/badgen"></script>
|
<script src="https://unpkg.com/badgen"></script>
|
||||||
<script>
|
<script>
|
||||||
var svgString = badgen.badgen({ /*...*/ })
|
var svgString = badgen({ /*...*/ })
|
||||||
</script>
|
</script>
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
Plik diff jest za duży
Load Diff
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "badgen",
|
"name": "badgen",
|
||||||
"version": "3.2.2",
|
"version": "3.2.3",
|
||||||
"description": "Fast svg badge generator.",
|
"description": "Fast svg badge generator.",
|
||||||
"repository": "amio/badgen",
|
"repository": "amio/badgen",
|
||||||
"author": "Amio <amio.cn@gmail.com>",
|
"author": "Amio <amio.cn@gmail.com>",
|
||||||
|
@ -13,7 +13,7 @@
|
||||||
"preview": "node preview/serve.js",
|
"preview": "node preview/serve.js",
|
||||||
"snaptests": "TAP_SNAPSHOT=1 npm test",
|
"snaptests": "TAP_SNAPSHOT=1 npm test",
|
||||||
"pretest": "npm run build",
|
"pretest": "npm run build",
|
||||||
"test": "tap test/*.spec.ts",
|
"test": "tap --no-check-coverage",
|
||||||
"prebuild": "rm -rf dist",
|
"prebuild": "rm -rf dist",
|
||||||
"esbuild": "esbuild src/index.ts --bundle --minify --sourcemap",
|
"esbuild": "esbuild src/index.ts --bundle --minify --sourcemap",
|
||||||
"build:types": "tsc --emitDeclarationOnly",
|
"build:types": "tsc --emitDeclarationOnly",
|
||||||
|
@ -26,9 +26,9 @@
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@types/node": "^14.0.14",
|
"@types/node": "^14.0.14",
|
||||||
"benchmark": "^2.1.4",
|
"benchmark": "^2.1.4",
|
||||||
"esbuild": "^0.8.17",
|
"esbuild": "^0.14.38",
|
||||||
"serve-marked": "^3.1.0",
|
"serve-marked": "^3.1.0",
|
||||||
"tap": "^14.10.7",
|
"tap": "^16.1.0",
|
||||||
"typescript": "^4.1.2"
|
"typescript": "^4.1.2"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
// import widthsVerdana110 from './widths-verdana-110.json'
|
// import widthsVerdana110 from './widths-verdana-110.json'
|
||||||
// @ts-ignore
|
// @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
|
const fallbackWidth = charWidthTable[64] // Width as "@" for overflows
|
||||||
|
|
||||||
return ([...text]) => {
|
return ([...text]) => {
|
||||||
|
|
|
@ -10,4 +10,4 @@ export default {
|
||||||
gray: '999',
|
gray: '999',
|
||||||
cyan: '1BC',
|
cyan: '1BC',
|
||||||
black: '2A2A2A'
|
black: '2A2A2A'
|
||||||
}
|
} as Record<string, string>
|
||||||
|
|
52
src/index.ts
52
src/index.ts
|
@ -2,12 +2,13 @@ export { Verdana110 as calcWidth } from './calc-text-width'
|
||||||
import { Verdana110 as calcWidth } from './calc-text-width'
|
import { Verdana110 as calcWidth } from './calc-text-width'
|
||||||
import colorPresets from './color-presets'
|
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;
|
status: string;
|
||||||
subject?: string;
|
subject?: string;
|
||||||
color?: string;
|
color?: ColorPreset;
|
||||||
label?: string;
|
label?: string;
|
||||||
labelColor?: string
|
labelColor?: string
|
||||||
style?: StyleOption;
|
style?: StyleOption;
|
||||||
|
@ -38,17 +39,23 @@ export function badgen ({
|
||||||
labelColor = colorPresets[labelColor] || labelColor
|
labelColor = colorPresets[labelColor] || labelColor
|
||||||
iconWidth = iconWidth * 10
|
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 sbTextStart = icon ? (iconSpanWidth + 50) : 50
|
||||||
const sbTextWidth = calcWidth(label)
|
const sbTextWidth = label ? calcWidth(label) : 0
|
||||||
const stTextWidth = calcWidth(status)
|
const stTextWidth = calcWidth(status)
|
||||||
const sbRectWidth = sbTextWidth + 100 + iconSpanWidth
|
const sbRectWidth = sbTextWidth + 100 + iconSpanWidth
|
||||||
const stRectWidth = stTextWidth + 100
|
const stRectWidth = stTextWidth + 100
|
||||||
const width = sbRectWidth + stRectWidth
|
const width = sbRectWidth + stRectWidth
|
||||||
const xlink = icon ? ' xmlns:xlink="http://www.w3.org/1999/xlink"' : ''
|
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)
|
status = sanitize(status)
|
||||||
|
color = sanitize(color)
|
||||||
|
labelColor = sanitize(labelColor)
|
||||||
|
icon = icon ? sanitize(icon) : icon
|
||||||
const accessibleText = createAccessibleText({label, status})
|
const accessibleText = createAccessibleText({label, status})
|
||||||
|
|
||||||
if (style === 'flat') {
|
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}">
|
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>
|
<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="0" stop-opacity=".1" stop-color="#EEE"/>
|
||||||
<stop offset="1" stop-opacity=".1"/>
|
<stop offset="1" stop-opacity=".1"/>
|
||||||
</linearGradient>
|
</linearGradient>
|
||||||
<mask id="m"><rect width="${width}" height="200" rx="30" fill="#FFF"/></mask>
|
<mask id="${maskId}"><rect width="${width}" height="200" rx="30" fill="#FFF"/></mask>
|
||||||
<g mask="url(#m)">
|
<g mask="url(#${maskId})">
|
||||||
<rect width="${sbRectWidth}" height="200" fill="#${labelColor}"/>
|
<rect width="${sbRectWidth}" height="200" fill="#${labelColor}"/>
|
||||||
<rect width="${stRectWidth}" height="200" fill="#${color}" x="${sbRectWidth}"/>
|
<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>
|
||||||
<g aria-hidden="true" fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
|
<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>
|
<text x="${sbTextStart + 10}" y="148" textLength="${sbTextWidth}" fill="#000" opacity="0.25">${label}</text>
|
||||||
|
@ -90,14 +97,18 @@ export function badgen ({
|
||||||
</svg>`
|
</svg>`
|
||||||
}
|
}
|
||||||
|
|
||||||
function bare ({ status, color, style, scale }) {
|
function bare ({ status, color = 'blue', style, scale = 1 }: BadgenOptions) {
|
||||||
typeAssert(typeof status === 'string', '<status> must be string')
|
typeAssert(typeof status === 'string', '<status> must be string')
|
||||||
color = colorPresets[color] || color || colorPresets.blue
|
color = colorPresets[color] || color || colorPresets.blue
|
||||||
|
|
||||||
const stTextWidth = calcWidth(status)
|
const stTextWidth = calcWidth(status)
|
||||||
const stRectWidth = stTextWidth + 115
|
const stRectWidth = stTextWidth + 115
|
||||||
|
|
||||||
|
const gradientId = generateRandomID(5)
|
||||||
|
const maskId = generateRandomID(5)
|
||||||
|
|
||||||
status = sanitize(status)
|
status = sanitize(status)
|
||||||
|
color = sanitize(color)
|
||||||
|
|
||||||
if (style === 'flat') {
|
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}">
|
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}">
|
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>
|
<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="0" stop-opacity=".1" stop-color="#EEE"/>
|
||||||
<stop offset="1" stop-opacity=".1"/>
|
<stop offset="1" stop-opacity=".1"/>
|
||||||
</linearGradient>
|
</linearGradient>
|
||||||
<mask id="m"><rect width="${stRectWidth}" height="200" rx="30" fill="#FFF"/></mask>
|
<mask id="${maskId}"><rect width="${stRectWidth}" height="200" rx="30" fill="#FFF"/></mask>
|
||||||
<g mask="url(#m)">
|
<g mask="url(#${maskId})">
|
||||||
<rect width="${stRectWidth}" height="200" fill="#${color}" x="0"/>
|
<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>
|
||||||
<g aria-hidden="true" fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
|
<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>
|
<text x="65" y="148" textLength="${stTextWidth}" fill="#000" opacity="0.25">${status}</text>
|
||||||
|
@ -144,6 +155,17 @@ interface AccessibleTextProps {
|
||||||
label?: string;
|
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 {
|
function createAccessibleText({label, status}: AccessibleTextProps): string {
|
||||||
const labelPrefix = label ? `${label}: ` : '';
|
const labelPrefix = label ? `${label}: ` : '';
|
||||||
return labelPrefix + status;
|
return labelPrefix + status;
|
||||||
|
|
|
@ -5,6 +5,48 @@
|
||||||
* Make sure to inspect the output below. Do not ignore changes!
|
* Make sure to inspect the output below. Do not ignore changes!
|
||||||
*/
|
*/
|
||||||
'use strict'
|
'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="<escape me>: <escape me>">
|
||||||
|
<title><escape me>: <escape me></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="#<escape me>"/>
|
||||||
|
<rect width="876" height="200" fill="#<escape me>" 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"><escape me></text>
|
||||||
|
<text x="210" y="138" textLength="776"><escape me></text>
|
||||||
|
<text x="1091" y="148" textLength="776" fill="#000" opacity="0.25"><escape me></text>
|
||||||
|
<text x="1081" y="138" textLength="776"><escape me></text>
|
||||||
|
</g>
|
||||||
|
<image x="40" y="35" width="130" height="130" xlink:href="<escape me>"/>
|
||||||
|
</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="<escape me>">
|
||||||
|
<title><escape me></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="#<escape me>" 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"><escape me></text>
|
||||||
|
<text x="55" y="138" textLength="776"><escape me></text>
|
||||||
|
</g>
|
||||||
|
</svg>
|
||||||
|
`
|
||||||
|
|
||||||
exports[`test/badgen.spec.ts TAP generate badge with { label, status } > snapshot 1`] = `
|
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">
|
<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>
|
<title>npm: v1.0.0</title>
|
||||||
|
|
|
@ -5,18 +5,18 @@
|
||||||
* Make sure to inspect the output below. Do not ignore changes!
|
* Make sure to inspect the output below. Do not ignore changes!
|
||||||
*/
|
*/
|
||||||
'use strict'
|
'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
|
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
|
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
|
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
|
550
|
||||||
`
|
`
|
||||||
|
|
|
@ -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="<escape me>: <escape me>">
|
||||||
|
<title><escape me>: <escape me></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="#<escape me>"/>
|
||||||
|
<rect width="876" height="200" fill="#<escape me>" 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"><escape me></text>
|
||||||
|
<text x="210" y="138" textLength="776"><escape me></text>
|
||||||
|
<text x="1091" y="148" textLength="776" fill="#000" opacity="0.25"><escape me></text>
|
||||||
|
<text x="1081" y="138" textLength="776"><escape me></text>
|
||||||
|
</g>
|
||||||
|
<image x="40" y="35" width="130" height="130" xlink:href="<escape me>"/>
|
||||||
|
</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="<escape me>">
|
||||||
|
<title><escape me></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="#<escape me>" 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"><escape me></text>
|
||||||
|
<text x="55" y="138" textLength="776"><escape me></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>
|
||||||
|
`
|
|
@ -5,18 +5,18 @@
|
||||||
* Make sure to inspect the output below. Do not ignore changes!
|
* Make sure to inspect the output below. Do not ignore changes!
|
||||||
*/
|
*/
|
||||||
'use strict'
|
'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
|
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
|
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
|
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
|
550
|
||||||
`
|
`
|
|
@ -1,6 +1,13 @@
|
||||||
import tap from 'tap'
|
const tap = require('tap')
|
||||||
import { badgen } from '../dist'
|
const { badgen } = require('../dist')
|
||||||
import * as icons from './assets/icon-data-uri.js'
|
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 => {
|
tap.test('generate badge with { label, status }', t => {
|
||||||
const svg = badgen({ label: 'npm', status: 'v1.0.0' })
|
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()
|
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 => {
|
tap.test('generate bare badge with { status }', t => {
|
||||||
const svg = badgen({ status: 'v1.0.0' })
|
const svg = badgen({ status: 'v1.0.0' })
|
||||||
t.ok(typeof svg === 'string', 'successfully generated')
|
t.ok(typeof svg === 'string', 'successfully generated')
|
||||||
|
@ -75,6 +94,15 @@ tap.test('generate bare badge with { status, style }', t => {
|
||||||
t.end()
|
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 => {
|
tap.test('type checking', t => {
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
t.throws(() => badgen({}), TypeError, 'throw if status is non-string')
|
t.throws(() => badgen({}), TypeError, 'throw if status is non-string')
|
|
@ -1,5 +1,5 @@
|
||||||
import tap from 'tap'
|
const tap = require('tap')
|
||||||
import { calcWidth } from '../dist'
|
const { calcWidth } = require('../dist')
|
||||||
|
|
||||||
tap.test('basic functions', t => {
|
tap.test('basic functions', t => {
|
||||||
t.ok(typeof calcWidth === 'function', 'export calcWidth function')
|
t.ok(typeof calcWidth === 'function', 'export calcWidth function')
|
|
@ -1,5 +1,7 @@
|
||||||
{
|
{
|
||||||
"compilerOptions": {
|
"compilerOptions": {
|
||||||
|
"strict": true,
|
||||||
|
|
||||||
"target": "es2017",
|
"target": "es2017",
|
||||||
"module": "commonjs",
|
"module": "commonjs",
|
||||||
"lib": ["esnext", "dom"],
|
"lib": ["esnext", "dom"],
|
||||||
|
@ -12,7 +14,8 @@
|
||||||
|
|
||||||
"resolveJsonModule": true,
|
"resolveJsonModule": true,
|
||||||
"experimentalDecorators": true,
|
"experimentalDecorators": true,
|
||||||
"allowSyntheticDefaultImports": true
|
"allowSyntheticDefaultImports": true,
|
||||||
|
"forceConsistentCasingInFileNames": true,
|
||||||
},
|
},
|
||||||
"include": ["src"]
|
"include": ["src"]
|
||||||
}
|
}
|
||||||
|
|
Ładowanie…
Reference in New Issue