31
server.js
31
server.js
@@ -245,10 +245,11 @@ cache(function(data, match, sendBadge) {
|
|||||||
}));
|
}));
|
||||||
|
|
||||||
// Packagist integration.
|
// Packagist integration.
|
||||||
camp.route(/^\/packagist\/dm\/(.*)\.(svg|png|gif|jpg)$/,
|
camp.route(/^\/packagist\/(dm|dd|dt)\/(.*)\.(svg|png|gif|jpg)$/,
|
||||||
cache(function(data, match, sendBadge) {
|
cache(function(data, match, sendBadge) {
|
||||||
var userRepo = match[1]; // eg, `doctrine/orm`.
|
var info = match[1]; // either `dm` or dt`.
|
||||||
var format = match[2];
|
var userRepo = match[2]; // eg, `doctrine/orm`.
|
||||||
|
var format = match[3];
|
||||||
var apiUrl = 'https://packagist.org/packages/' + userRepo + '.json';
|
var apiUrl = 'https://packagist.org/packages/' + userRepo + '.json';
|
||||||
var badgeData = getBadgeData('downloads', data);
|
var badgeData = getBadgeData('downloads', data);
|
||||||
request(apiUrl, function(err, res, buffer) {
|
request(apiUrl, function(err, res, buffer) {
|
||||||
@@ -258,15 +259,27 @@ cache(function(data, match, sendBadge) {
|
|||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
var data = JSON.parse(buffer);
|
var data = JSON.parse(buffer);
|
||||||
var monthly = data.package.downloads.monthly;
|
switch (info.charAt(1)) {
|
||||||
badgeData.text[1] = metric(monthly) + '/month';
|
case 'm':
|
||||||
if (monthly === 0) {
|
var downloads = data.package.downloads.monthly;
|
||||||
|
badgeData.text[1] = metric(downloads) + '/month';
|
||||||
|
break;
|
||||||
|
case 'd':
|
||||||
|
var downloads = data.package.downloads.daily;
|
||||||
|
badgeData.text[1] = metric(downloads) + '/day';
|
||||||
|
break;
|
||||||
|
case 't':
|
||||||
|
var downloads = data.package.downloads.total;
|
||||||
|
badgeData.text[1] = metric(downloads) + ' total';
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (downloads === 0) {
|
||||||
badgeData.colorscheme = 'red';
|
badgeData.colorscheme = 'red';
|
||||||
} else if (monthly < 10) {
|
} else if (downloads < 10) {
|
||||||
badgeData.colorscheme = 'yellow';
|
badgeData.colorscheme = 'yellow';
|
||||||
} else if (monthly < 100) {
|
} else if (downloads < 100) {
|
||||||
badgeData.colorscheme = 'yellowgreen';
|
badgeData.colorscheme = 'yellowgreen';
|
||||||
} else if (monthly < 1000) {
|
} else if (downloads < 1000) {
|
||||||
badgeData.colorscheme = 'green';
|
badgeData.colorscheme = 'green';
|
||||||
} else {
|
} else {
|
||||||
badgeData.colorscheme = 'brightgreen';
|
badgeData.colorscheme = 'brightgreen';
|
||||||
|
|||||||
8
try.html
8
try.html
@@ -157,6 +157,14 @@ I made the GitHub Badge Service.
|
|||||||
<td><img src='/packagist/dm/doctrine/orm.svg' alt=''/></td>
|
<td><img src='/packagist/dm/doctrine/orm.svg' alt=''/></td>
|
||||||
<td><code>http://img.shields.io/packagist/dm/doctrine/orm.svg</code></td>
|
<td><code>http://img.shields.io/packagist/dm/doctrine/orm.svg</code></td>
|
||||||
</tr>
|
</tr>
|
||||||
|
<tr><th> Packagist: </th>
|
||||||
|
<td><img src='/packagist/dd/doctrine/orm.svg' alt=''/></td>
|
||||||
|
<td><code>http://img.shields.io/packagist/dd/doctrine/orm.svg</code></td>
|
||||||
|
</tr>
|
||||||
|
<tr><th> Packagist: </th>
|
||||||
|
<td><img src='/packagist/dt/doctrine/orm.svg' alt=''/></td>
|
||||||
|
<td><code>http://img.shields.io/packagist/dt/doctrine/orm.svg</code></td>
|
||||||
|
</tr>
|
||||||
</tbody></table>
|
</tbody></table>
|
||||||
<h3> Version </h3>
|
<h3> Version </h3>
|
||||||
<table><tbody>
|
<table><tbody>
|
||||||
|
|||||||
Reference in New Issue
Block a user