Github - package.json dependency linker

When viewing a package.json file, automatically links dependencies to their NPM page

От 08.10.2014. Виж последната версия.

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey, Greasemonkey или Violentmonkey.

You will need to install an extension such as Tampermonkey to install this script.

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey или Violentmonkey.

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey или Userscripts.

За да инсталирате скрипта, трябва да инсталирате разширение като Tampermonkey.

За да инсталирате този скрипт, трябва да имате инсталиран скриптов мениджър.

(Вече имам скриптов мениджър, искам да го инсталирам!)

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

(Вече имам инсталиран мениджър на стиловете, искам да го инсталирам!)

// ==UserScript==
// @name           Github - package.json dependency linker
// @description    When viewing a package.json file, automatically links dependencies to their NPM page
// @author         James Skinner <[email protected]> http://userscripts.org/users/55684
// @namespace      http://spiralx.org/
// @license        BSD
// @version        0.0.2
// @include        https://github.com/*/package.json
// @require        https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.js
// ==/UserScript==

function format(formatString, data) {
  data = arguments.length == 2 && typeof data === "object" && !Array.isArray(data)
    ? data
    : [].slice.call(arguments, 1);

  return formatString
    .replace(/\{\{/g, String.fromCharCode(0))
    .replace(/\}\}/g, String.fromCharCode(1))
    .replace(/\{([^}]+)\}/g, function(match, path) {
      try {
        var p = path.replace(/\[(-?\w+)\]/g, '.$1').split('.');
        //console.log('path="%s" (%s), data=%s', path, p.toSource(), data.toSource());
        return String(p.reduce(function(o, n) {
          return o.slice && !isNaN(n) ? o.slice(n).shift() :  o[n];
        }, data));
      }
      catch (ex) {
        return match;
      }
    })
    .replace(/\x00/g, "{")
    .replace(/\x01/g, "}");
}

// --------------------------------------------------------------------------

var $code = $('.highlight .js-file-line'),
  pkg = JSON.parse($code.text()),
  depKeys = [
    "dependencies",
    "devDependencies",
    "peerDependencies",
    "bundleDependencies",
    "bundledDependencies",
    "optionalDependencies"
  ];
  
depKeys.forEach(function(k) {
  var deps = pkg[k] || {};
  
  for (var module in deps) {
    var
      url = 'https://www.npmjs.org/package/' + module,
      // jsonUrl = 'http://registry.npmjs.org/' + module + '/latest',
      t = '"' + module + '"';
      
    $code
      .find('.nt')
      .filter(function() {
        return $(this).text().trim() === t
      })
      .html(format('"<a href="{0}">{1}</a>"', url, module));
  }
});