react-docgen
Version:
A CLI and toolkit to extract information from React components for documentation generation.
82 lines (63 loc) • 1.96 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = resolveToModule;
var _match = _interopRequireDefault(require("./match"));
var _recast = _interopRequireDefault(require("recast"));
var _resolveToValue = _interopRequireDefault(require("./resolveToValue"));
/*
* Copyright (c) 2015, Facebook, Inc.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*
*
*
*/
const types = _recast.default.types.namedTypes;
/**
* Given a path (e.g. call expression, member expression or identifier),
* this function tries to find the name of module from which the "root value"
* was imported.
*/
function resolveToModule(path) {
const node = path.node;
switch (node.type) {
case types.VariableDeclarator.name:
if (node.init) {
return resolveToModule(path.get('init'));
}
break;
case types.CallExpression.name:
if ((0, _match.default)(node.callee, {
type: types.Identifier.name,
name: 'require'
})) {
return node.arguments[0].value;
}
return resolveToModule(path.get('callee'));
case types.Identifier.name:
case types.JSXIdentifier.name:
{
const valuePath = (0, _resolveToValue.default)(path);
if (valuePath !== path) {
return resolveToModule(valuePath);
}
break;
}
case types.ImportDeclaration.name:
return node.source.value;
case types.MemberExpression.name:
while (path && types.MemberExpression.check(path.node)) {
path = path.get('object');
}
if (path) {
return resolveToModule(path);
}
}
return null;
}