Merge remote-tracking branch 'sagiegurari/master'
This commit is contained in:
commit
2885db547f
|
@ -228,6 +228,10 @@ Pixel-perfect Retina-ready Fast Consistent Hackable
|
||||||
<td><img src='https://img.shields.io/npm/dm/localeval.svg' alt=''/></td>
|
<td><img src='https://img.shields.io/npm/dm/localeval.svg' alt=''/></td>
|
||||||
<td><code>https://img.shields.io/npm/dm/localeval.svg</code></td>
|
<td><code>https://img.shields.io/npm/dm/localeval.svg</code></td>
|
||||||
</tr>
|
</tr>
|
||||||
|
<tr><th data-keywords='node'> npm: </th>
|
||||||
|
<td><img src='https://img.shields.io/npm/dt/express.svg' alt=''/></td>
|
||||||
|
<td><code>https://img.shields.io/npm/dt/express.svg</code></td>
|
||||||
|
</tr>
|
||||||
<tr><th data-keywords='ruby'> Gem: </th>
|
<tr><th data-keywords='ruby'> Gem: </th>
|
||||||
<td><img src='https://img.shields.io/gem/dv/rails/stable.svg' alt=''/></td>
|
<td><img src='https://img.shields.io/gem/dv/rails/stable.svg' alt=''/></td>
|
||||||
<td><code>https://img.shields.io/gem/dv/rails/stable.svg</code></td>
|
<td><code>https://img.shields.io/gem/dv/rails/stable.svg</code></td>
|
||||||
|
|
36
server.js
36
server.js
|
@ -1236,6 +1236,42 @@ cache(function(data, match, sendBadge, request) {
|
||||||
});
|
});
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
// npm total download integration.
|
||||||
|
camp.route(/^\/npm\/dt\/(.*)\.(svg|png|gif|jpg|json)$/,
|
||||||
|
cache(function (data, match, sendBadge, request) {
|
||||||
|
var pkg = encodeURIComponent(match[1]); // eg, "express" or "@user/express"
|
||||||
|
var format = match[2];
|
||||||
|
var apiUrl = 'https://api.npmjs.org/downloads/range/1000-01-01:3000-01-01/' + pkg; // use huge range, will need to fix this in year 3000 :)
|
||||||
|
var badgeData = getBadgeData('downloads', data);
|
||||||
|
request(apiUrl, function (err, res, buffer) {
|
||||||
|
if (err != null) {
|
||||||
|
badgeData.text[1] = 'inaccessible';
|
||||||
|
sendBadge(format, badgeData);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
var totalDownloads = 0;
|
||||||
|
|
||||||
|
var downloads = JSON.parse(buffer).downloads;
|
||||||
|
for (var index = 0; index < downloads.length; index++) {
|
||||||
|
totalDownloads = totalDownloads + downloads[index].downloads;
|
||||||
|
}
|
||||||
|
|
||||||
|
badgeData.text[1] = metric(totalDownloads) + ' total';
|
||||||
|
if (totalDownloads === 0) {
|
||||||
|
badgeData.colorscheme = 'red';
|
||||||
|
} else {
|
||||||
|
badgeData.colorscheme = 'brightgreen';
|
||||||
|
}
|
||||||
|
sendBadge(format, badgeData);
|
||||||
|
} catch (e) {
|
||||||
|
badgeData.text[1] = 'invalid';
|
||||||
|
sendBadge(format, badgeData);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}));
|
||||||
|
|
||||||
// npm version integration.
|
// npm version integration.
|
||||||
camp.route(/^\/npm\/v\/(.*)\.(svg|png|gif|jpg|json)$/,
|
camp.route(/^\/npm\/v\/(.*)\.(svg|png|gif|jpg|json)$/,
|
||||||
cache(function(data, match, sendBadge, request) {
|
cache(function(data, match, sendBadge, request) {
|
||||||
|
|
4
try.html
4
try.html
|
@ -227,6 +227,10 @@ Pixel-perfect Retina-ready Fast Consistent Hackable
|
||||||
<td><img src='/npm/dm/localeval.svg' alt=''/></td>
|
<td><img src='/npm/dm/localeval.svg' alt=''/></td>
|
||||||
<td><code>https://img.shields.io/npm/dm/localeval.svg</code></td>
|
<td><code>https://img.shields.io/npm/dm/localeval.svg</code></td>
|
||||||
</tr>
|
</tr>
|
||||||
|
<tr><th data-keywords='node'> npm: </th>
|
||||||
|
<td><img src='/npm/dt/express.svg' alt=''/></td>
|
||||||
|
<td><code>https://img.shields.io/npm/dt/express.svg</code></td>
|
||||||
|
</tr>
|
||||||
<tr><th data-keywords='ruby'> Gem: </th>
|
<tr><th data-keywords='ruby'> Gem: </th>
|
||||||
<td><img src='/gem/dv/rails/stable.svg' alt=''/></td>
|
<td><img src='/gem/dv/rails/stable.svg' alt=''/></td>
|
||||||
<td><code>https://img.shields.io/gem/dv/rails/stable.svg</code></td>
|
<td><code>https://img.shields.io/gem/dv/rails/stable.svg</code></td>
|
||||||
|
|
Loading…
Reference in New Issue
Block a user