fix: iconWidth scale in 10x units

pull/15/head
Amio 2018-08-24 13:26:08 +08:00
rodzic 17da1cbd69
commit db811100d4
3 zmienionych plików z 32 dodań i 1 usunięć

Wyświetl plik

@ -1,10 +1,11 @@
const calcWidth = require('./calc-text-width.js').Verdana110
const colorPresets = require('./color-presets.js')
module.exports = ({ subject, status, color, style, icon, iconWidth = 130 }) => {
module.exports = ({ subject, status, color, style, icon, iconWidth = 13 }) => {
typeAssert(typeof subject === 'string', '<subject> must be string')
typeAssert(typeof status === 'string', '<status> must be string')
color = colorPresets[color] || color || colorPresets['blue']
iconWidth = iconWidth * 10
const iconSpanWidth = icon ? (subject.length ? iconWidth + 40 : iconWidth - 20) : 0
const sbTextWidth = calcWidth(subject)

Wyświetl plik

@ -137,6 +137,30 @@ exports[`test/index.spec.js TAP generate badge with { status, icon } > snapshot
`
exports[`test/index.spec.js TAP generate badge with { status, icon, iconWidth } > snapshot 1`] = `
<svg width="55.4" height="20" viewBox="0 0 554 200" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<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="554" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#m)">
<rect width="230" height="200" fill="#555"/>
<rect width="324" height="200" fill="#08C" x="230"/>
<rect width="554" height="200" fill="url(#a)"/>
</g>
<g fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="225" y="148" textLength="0" fill="#000" opacity="0.25"></text>
<text x="215" y="138" textLength="0"></text>
<text x="285" y="148" textLength="224" fill="#000" opacity="0.25">icon</text>
<text x="275" y="138" textLength="224">icon</text>
</g>
<image x="39" y="35" width="150" height="130" xlink:href=""/>
</svg>
`
exports[`test/index.spec.js TAP generate badge with { subject, status, icon, style } > snapshot 1`] = `
<svg width="96.5" height="20" viewBox="0 0 965 200" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">

Wyświetl plik

@ -42,6 +42,12 @@ tap.test('generate badge with { status, icon }', t => {
t.end()
})
tap.test('generate badge with { status, icon, iconWidth }', t => {
const svg = badgen({ subject: '', status: 'icon', icon, iconWidth: 15 })
t.matchSnapshot(svg, 'snapshot')
t.end()
})
tap.test('generate badge with { subject, status, icon, style }', t => {
const svg = badgen({ subject: 'docker', status: 'icon', style: 'flat', icon })
t.matchSnapshot(svg, 'snapshot')