You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
Amio a027565f9d Refine error handling 5 years ago
.github Create FUNDING.yml 5 years ago
components Cleanup legacy style files 5 years ago
endpoints Add BadgenError for error handling 5 years ago
libs Refine error handling 5 years ago
pages Cleanup legacy style files 5 years ago
static Cleanup legacy style files 5 years ago
test Remove "/" in plus segment in matchRoute 5 years ago
tools Serve docs with serve-marked 5 years ago
.babelrc Merge remote-tracking branch 'origin' into 2.0 5 years ago
.codeclimate.yml chore: add .codeclimate.yml 6 years ago
.gitignore Rearrange output dirs 5 years ago
.travis.yml chore: add .travis.yml 6 years ago
LICENSE.md chore: add license and improve readme (#89) 6 years ago
README.md Remove empty section (no backer yet) 5 years ago
index.ts Add cache-control header to statics 5 years ago
next.config.js Arrange assets folder 5 years ago
nodemon.json Add nodemon config 5 years ago
now-v2.json Add deploy config for Now v1 5 years ago
now.json Add deploy config for Now v1 5 years ago
package-lock.json Add nodemon config 5 years ago
package.json Add nodemon config 5 years ago
tsconfig.json Arrange assets folder 5 years ago

README.md

Badgen Service

Home of badgen.net, fast badge generating service.

The Badgen Story

That's a service, that's a library, hooorey! - @tunnckoCore

Finally something to replace http://shields.io - @EGOIST

Epic work on Badgen! Porting the @dependabot badges over to it now. ️ - @greybaker

The badgen library was born as an exploration of "is it possible to generate badge SVG markup directly with JavaScript (without using pdfkit/canvas/puppeteer to measure text length)?". The result is better than I expected, Verdana (the de-facto font for badges) text width can be calculated precisely with a prebuilt char-width-table, even no need to worry about kerning 🤯

Then, logically, Badgen Service was born. I had a good time with shields.io, but as time goes by Shields gets slower, leaves more and more broken badges in READMEs. Badgen is trying to be a fast alternative with simplicity and flexibility. Its codebase is simple (2K LoCs vs Shields' 22K LoCs), well structured and fun to develop - it is pretty easy to add badge(s) for new service(s).

In the beginning, I was considering both Now and Google Cloud Functions. Then Zeit announced Now CDN on the same day as badgen.now.sh (the PoC of Badgen Service)'s reveal, what a fate! Cloudflare powered Now CDN is a perfect choice for such service, caching and scalability in simplicity. Badgen is the fastest possible badge generating service out there. It's fast, it's reliable, it's globally distributed and cached, thanks to Now.

At the time of badgen.now.sh's reveal, it had only four live badges as demonstrations. Since then, thanks to awesome people's help, Badgen keeps getting better at a fast pace. Welcome to join us, let's build the best badge service in the universe 🔥

Anatomy

  • Written in TypeScript => better develop experience
  • Using badgen library to generate svg on the fly => fast & stateless
  • Hosted on Now, serving behind Now CDN => faster & reliable
  • Cache less than 4 minutes => fresh & hot
  • Two styles:
  • Two badge types
    • static badge - URL defined badge (subject, status, color)
    • live badge - show live status from 3rd party services
  • Builtin Icons

Developing

Contributors StandardJS Dependencies Maintainability Code Quality LGTM Alerts

We are using StandardJS style, make sure you have ESLint/Standard plugin on your editor and have autofix enabled.

Add live badge

If a service you wish to have is still missing here, we welcome new contributions. Basically, you need to add a file in endpoints/[name-of-service].ts and that's it. Take crates as an example:

To ensure that your addition is working correctly, start the development server with npm run dev.

YOU MAY NOT NEED TO MAKE PULL REQUEST

You can create arbitrary live badge with RunKit's online IDE, or any https endpoint. Checkout docs: /runkit or /https.

Add icon

You can contribute icons to badgen-icons. Please make sure new icon is optimized using svgomg.

Tracking Policy

Badgen use Google Analytics on doc pages (home, /docs/packagephobia, etc.), log request time to 3rd party service for live badges, like:

2018-08-09T04:16:30.947Z  #npm dt/chalk: 160.519ms
2018-08-09T04:16:31.195Z  #npm dependents/chalk: 365.045ms
2018-08-09T04:16:51.252Z  #david dep/olstenlarck/eslint-config-esmc: 445.893ms

And that's all. No tracking of end users.

About

Made with ❤️ by Amio, built with ️ from badgen.

Contributors

This project exists thanks to all the people who contribute.