gem downloads count
This commit is contained in:
parent
dc6c5c836a
commit
fc5ee65379
48
server.js
48
server.js
|
@ -588,6 +588,44 @@ cache(function(data, match, sendBadge) {
|
||||||
});
|
});
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
// Gem download count integration.
|
||||||
|
camp.route(/^\/gem\/dc\/(.*)\.(svg|png|gif|jpg)$/,
|
||||||
|
cache(function(data, match, sendBadge) {
|
||||||
|
var site = match[1];
|
||||||
|
var repo = site.split('/')[0];
|
||||||
|
var downloads_type = site.split('/')[1];
|
||||||
|
var format = match[2];
|
||||||
|
var apiUrl = 'https://rubygems.org/api/v1/gems/' + repo + '.json';
|
||||||
|
var badgeData = getBadgeData('downloads', data);
|
||||||
|
request(apiUrl, { headers: { 'Accept': 'application/atom+json,application/json' } }, function(err, res, buffer) {
|
||||||
|
if (err != null) {
|
||||||
|
badgeData.text[1] = 'inaccessible';
|
||||||
|
sendBadge(format, badgeData);
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
var data = JSON.parse(buffer);
|
||||||
|
var downloads = 0;
|
||||||
|
if (typeof (downloads_type) !== "undefined" && downloads_type === "total") {
|
||||||
|
downloads = data.downloads;
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
downloads = data.version_downloads;
|
||||||
|
}
|
||||||
|
badgeData.text[1] = number_with_delimiter(downloads);
|
||||||
|
if (typeof(downloads_type) !== "undefined" && downloads_type === "total" )
|
||||||
|
{
|
||||||
|
badgeData.text[1] = badgeData.text[1] + ' total';
|
||||||
|
}
|
||||||
|
badgeData.colorscheme = downloadCountColor(downloads);
|
||||||
|
sendBadge(format, badgeData);
|
||||||
|
} catch(e) {
|
||||||
|
badgeData.text[1] = 'invalid';
|
||||||
|
sendBadge(format, badgeData);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}));
|
||||||
|
|
||||||
|
|
||||||
// PyPI integration.
|
// PyPI integration.
|
||||||
camp.route(/^\/pypi\/([^\/]+)\/(.*)\.(svg|png|gif|jpg)$/,
|
camp.route(/^\/pypi\/([^\/]+)\/(.*)\.(svg|png|gif|jpg)$/,
|
||||||
cache(function(data, match, sendBadge) {
|
cache(function(data, match, sendBadge) {
|
||||||
|
@ -1409,6 +1447,16 @@ function metric(n) {
|
||||||
return ''+n;
|
return ''+n;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function number_with_delimiter (number, delimiter) {
|
||||||
|
var number = number + '', delimiter = delimiter || ',';
|
||||||
|
var split = number.split('.');
|
||||||
|
split[0] = split[0].replace(
|
||||||
|
/(\d)(?=(\d\d\d)+(?!\d))/g,
|
||||||
|
'$1' + delimiter
|
||||||
|
);
|
||||||
|
return split.join('.');
|
||||||
|
};
|
||||||
|
|
||||||
function coveragePercentageColor(percentage) {
|
function coveragePercentageColor(percentage) {
|
||||||
if (percentage < 80) {
|
if (percentage < 80) {
|
||||||
return 'red';
|
return 'red';
|
||||||
|
|
8
try.html
8
try.html
|
@ -167,6 +167,14 @@ I made the GitHub Badge Service.
|
||||||
</tbody></table>
|
</tbody></table>
|
||||||
<h3> Downloads </h3>
|
<h3> Downloads </h3>
|
||||||
<table><tbody>
|
<table><tbody>
|
||||||
|
<tr><th> Gem </th>
|
||||||
|
<td><img src='/gem/dc/rails.svg' alt=''/></td>
|
||||||
|
<td><code>http://img.shields.io/gem/dc/rails.svg</code></td>
|
||||||
|
</tr>
|
||||||
|
<tr><th> Gem </th>
|
||||||
|
<td><img src='/gem/dc/rails/total.svg' alt=''/></td>
|
||||||
|
<td><code>http://img.shields.io/gem/dc/rails/total.svg</code></td>
|
||||||
|
</tr>
|
||||||
<tr><th> npm: </th>
|
<tr><th> npm: </th>
|
||||||
<td><img src='/npm/dm/localeval.svg' alt=''/></td>
|
<td><img src='/npm/dm/localeval.svg' alt=''/></td>
|
||||||
<td><code>http://img.shields.io/npm/dm/localeval.svg</code></td>
|
<td><code>http://img.shields.io/npm/dm/localeval.svg</code></td>
|
||||||
|
|
Loading…
Reference in New Issue
Block a user