1
0
mirror of https://github.com/badgen/badgen-cli.git synced 2025-04-19 05:22:20 +03:00

First commit 🎉

This commit is contained in:
Guillaume Martigny 2019-05-03 12:12:59 +02:00 committed by Guillaume Martigny
parent a03fe524c1
commit 2adee88543
7 changed files with 6601 additions and 0 deletions

3
.gitignore vendored Normal file
View File

@ -0,0 +1,3 @@
.idea/
.nyc_output/
node_modules/

78
cli.js Executable file
View File

@ -0,0 +1,78 @@
#!/usr/bin/env node
const meow = require('meow')
const badgen = require('badgen')
const icons = require('badgen-icons')
const flags = {
status: {
type: 'string',
alias: 's'
},
subject: {
type: 'string',
alias: 'j',
default: ''
},
color: {
type: 'string',
alias: 'c'
},
flat: {
type: 'boolean',
alias: 'f'
},
icon: {
type: 'string',
alias: 'i'
},
iconWidth: {
type: 'string',
alias: 'w'
}
}
const cli = meow(`
Usage
$ badgen <options>
Options
--status, -s (required) Status of the badge, right part
--subject, -j Subject of the badge, left part
--color, -c Color of the status
--flat, -f Use the flat badge style
--icon, -i Icon to use
--icon-width, -w Width of the icon if not square
Example
$ badgen --subject test --status ok --color green --icon terminal --flat > test.svg
`, {
flags
})
const options = {}
// Normalize flag to keep the last override
// Might be unnecessary when https://github.com/sindresorhus/meow/issues/111 is resolved
Object.keys(flags).forEach(key => {
let flag = cli.flags[key]
if (Array.isArray(flag)) {
flag = flag[flag.length - 1]
}
options[key] = flag
})
options.style = options.flat && 'flat'
const icon = icons[options.icon === '' ? options.subject : options.icon]
options.icon = icon && icon.base64 || ''
options.iconWidth = options.iconWidth || icon && icon.width || null
try {
const svg = badgen(options)
console.log(svg)
} catch (error) {
console.error(error.message)
}

6229
package-lock.json generated Normal file

File diff suppressed because it is too large Load Diff

37
package.json Normal file
View File

@ -0,0 +1,37 @@
{
"name": "badgen-cli",
"version": "0.0.1",
"description": "",
"keywords": [
"cli",
"badge",
"svg"
],
"bin": {
"badgen": "cli.js"
},
"scripts": {
"lint": "standart",
"test": "tap"
},
"repository": {
"type": "git",
"url": "git+https://github.com/badgen/badgen-cli.git"
},
"author": "GMartigny <guillaume.martigny@gmail.com>",
"license": "ISC",
"bugs": {
"url": "https://github.com/badgen/badgen-cli/issues"
},
"homepage": "https://github.com/badgen/badgen-cli#readme",
"dependencies": {
"badgen": "^2.7.1",
"badgen-icons": "^0.8.0",
"meow": "^5.0.0"
},
"devDependencies": {
"execa": "^1.0.0",
"standart": "^6.1.0",
"tap": "^13.1.2"
}
}

34
readme.md Normal file
View File

@ -0,0 +1,34 @@
# Badgen-cli
Use the fastest badge generator from your CLI.
## Installation
$ npm install -g badgen-cli
## Usage
$ badgen --subject build --status ok --color green > build-ok.svg
## Options
* `--status`, `-s`<br>
(required) String, Right-hand side of the badge
* `--subject`, `-j`<br>
String, left-hand side of the badge
* `--color`, `-c`<br>
String, color for the status (color name or RGB hexa value)
* `--flat`, `-f`<br>
Boolean, use the flat style badge
* `--icon`, `-i`<br>
String, icon before the subject (icon name, image data URI or inferred from the subject)
* `--icon-width`, `-w`<br>
Number, width of the icon if not square
## See also
[Badgen](https://github.com/badgen/badgen), the module behind this CLI.
## License
[ISC](license)

View File

@ -0,0 +1,164 @@
/* 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/index.spec.js TAP Assert icon from subject > Assert icon from subject 1`] = `
<svg width="90.9" height="20" viewBox="0 0 909 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="909" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#m)">
<rect width="677" height="200" fill="#555"/>
<rect width="232" height="200" fill="#08C" x="677"/>
<rect width="909" height="200" fill="url(#a)"/>
</g>
<g fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="220" y="148" textLength="417" fill="#000" opacity="0.25">chrome</text>
<text x="210" y="138" textLength="417">chrome</text>
<text x="732" y="148" textLength="132" fill="#000" opacity="0.25">ok</text>
<text x="722" y="138" textLength="132">ok</text>
</g>
<image x="40" y="35" width="130" height="130" xlink:href=""/>
</svg>
`
exports[`test/index.spec.js TAP Override properties > Override properties 1`] = `
<svg width="54.1" height="20" viewBox="0 0 541 200" xmlns="http://www.w3.org/2000/svg">
<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="541" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#m)">
<rect width="309" height="200" fill="#555"/>
<rect width="232" height="200" fill="#3C1" x="309"/>
<rect width="541" height="200" fill="url(#a)"/>
</g>
<g fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="60" y="148" textLength="209" fill="#000" opacity="0.25">test</text>
<text x="50" y="138" textLength="209">test</text>
<text x="364" y="148" textLength="132" fill="#000" opacity="0.25">ok</text>
<text x="354" y="138" textLength="132">ok</text>
</g>
</svg>
`
exports[`test/index.spec.js TAP Status and color > Status and color 1`] = `
<svg width="24.7" height="20" viewBox="0 0 247 200" xmlns="http://www.w3.org/2000/svg">
<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="247" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#m)">
<rect width="247" height="200" fill="#E43" x="0"/>
<rect width="247" height="200" fill="url(#a)"/>
</g>
<g fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="65" y="148" textLength="132" fill="#000" opacity="0.25">ok</text>
<text x="55" y="138" textLength="132">ok</text>
</g>
</svg>
`
exports[`test/index.spec.js TAP Status and flat > Status and flat 1`] = `
<svg width="24.7" height="20" viewBox="0 0 247 200" xmlns="http://www.w3.org/2000/svg">
<g>
<rect fill="#08C" x="0" width="247" height="200"/>
</g>
<g fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="65" y="148" textLength="132" fill="#000" opacity="0.1">ok</text>
<text x="55" y="138" textLength="132">ok</text>
</g>
</svg>
`
exports[`test/index.spec.js TAP Status and icon > Status and icon 1`] = `
<svg width="44.4" height="20" viewBox="0 0 444 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="444" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#m)">
<rect width="212" height="200" fill="#555"/>
<rect width="232" height="200" fill="#08C" x="212"/>
<rect width="444" height="200" fill="url(#a)"/>
</g>
<g 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="132" fill="#000" opacity="0.25">ok</text>
<text x="257" y="138" textLength="132">ok</text>
</g>
<image x="40" y="35" width="130" height="130" xlink:href=""/>
</svg>
`
exports[`test/index.spec.js TAP Status only > Status only 1`] = `
<svg width="24.7" height="20" viewBox="0 0 247 200" xmlns="http://www.w3.org/2000/svg">
<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="247" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#m)">
<rect width="247" height="200" fill="#08C" x="0"/>
<rect width="247" height="200" fill="url(#a)"/>
</g>
<g fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="65" y="148" textLength="132" fill="#000" opacity="0.25">ok</text>
<text x="55" y="138" textLength="132">ok</text>
</g>
</svg>
`
exports[`test/index.spec.js TAP Subject and status > Subject and status 1`] = `
<svg width="54.1" height="20" viewBox="0 0 541 200" xmlns="http://www.w3.org/2000/svg">
<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="541" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#m)">
<rect width="309" height="200" fill="#555"/>
<rect width="232" height="200" fill="#08C" x="309"/>
<rect width="541" height="200" fill="url(#a)"/>
</g>
<g fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="60" y="148" textLength="209" fill="#000" opacity="0.25">test</text>
<text x="50" y="138" textLength="209">test</text>
<text x="364" y="148" textLength="132" fill="#000" opacity="0.25">ok</text>
<text x="354" y="138" textLength="132">ok</text>
</g>
</svg>
`
exports[`test/index.spec.js TAP Subject, status and icon > Subject, status and icon 1`] = `
<svg width="70.1" height="20" viewBox="0 0 701 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="701" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#m)">
<rect width="469" height="200" fill="#555"/>
<rect width="232" height="200" fill="#08C" x="469"/>
<rect width="701" height="200" fill="url(#a)"/>
</g>
<g fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="220" y="148" textLength="209" fill="#000" opacity="0.25">test</text>
<text x="210" y="138" textLength="209">test</text>
<text x="524" y="148" textLength="132" fill="#000" opacity="0.25">ok</text>
<text x="514" y="138" textLength="132">ok</text>
</g>
<image x="40" y="35" width="130" height="130" xlink:href=""/>
</svg>
`

56
test/index.spec.js Normal file
View File

@ -0,0 +1,56 @@
const tap = require('tap')
const execa = require('execa')
const check = async (t, params) => {
const result = await execa('./cli.js', params)
if (result.stderr) {
t.fail()
} else {
t.matchSnapshot(result.stdout, t.name)
}
}
tap.test('No status', async t => {
const error = await execa.stderr('./cli.js')
t.ok(error.includes('status'))
})
tap.test('Status only', async t => {
await check(t, ['--status', 'ok'])
t.end()
})
tap.test('Subject and status', async t => {
await check(t, ['--subject', 'test', '--status', 'ok'])
t.end()
})
tap.test('Status and color', async t => {
await check(t, ['--status', 'ok', '--color', 'red'])
t.end()
})
tap.test('Status and flat', async t => {
await check(t, ['--status', 'ok', '--flat'])
t.end()
})
tap.test('Assert icon from subject', async t => {
await check(t, ['--subject', 'chrome', '--status', 'ok', '--icon'])
t.end()
})
tap.test('Status and icon', async t => {
await check(t, ['--status', 'ok', '--icon', 'npm'])
t.end()
})
tap.test('Subject, status and icon', async t => {
await check(t, ['--subject', 'test', '--status', 'ok', '--icon', 'git'])
t.end()
})
tap.test('Override properties', async t => {
await check(t, ['--subject', 'test', '--status', 'fail', '--color', 'red', '--status', 'ok', '--color', 'green'])
t.end()
})