2015-02-12 11:51:52 -08:00
|
|
|
/*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @flow
|
|
|
|
*/
|
|
|
|
"use strict";
|
|
|
|
|
|
|
|
var Documentation = require('../Documentation');
|
|
|
|
|
|
|
|
var getDocblock = require('../utils/docblock').getDocblock;
|
|
|
|
var getPropertyName = require('../utils/getPropertyName');
|
2015-03-02 17:31:26 -08:00
|
|
|
var getPropertyValuePath = require('../utils/getPropertyValuePath');
|
2015-03-04 13:37:05 -08:00
|
|
|
var types = require('recast').types.namedTypes;
|
|
|
|
var resolveToValue = require('../utils/resolveToValue');
|
2015-02-12 11:51:52 -08:00
|
|
|
|
|
|
|
function propDocBlockHandler(documentation: Documentation, path: NodePath) {
|
2015-03-05 00:37:02 -08:00
|
|
|
var propTypesPath = getPropertyValuePath(path, 'propTypes');
|
|
|
|
if (!propTypesPath) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
propTypesPath = resolveToValue(propTypesPath);
|
2015-03-02 17:31:26 -08:00
|
|
|
if (!propTypesPath || !types.ObjectExpression.check(propTypesPath.node)) {
|
2015-02-12 11:51:52 -08:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2015-03-02 17:31:26 -08:00
|
|
|
propTypesPath.get('properties').each(function(propertyPath) {
|
2015-02-12 11:51:52 -08:00
|
|
|
// we only support documentation of actual properties, not spread
|
|
|
|
if (types.Property.check(propertyPath.node)) {
|
|
|
|
var propDescriptor = documentation.getPropDescriptor(
|
|
|
|
getPropertyName(propertyPath)
|
|
|
|
);
|
|
|
|
propDescriptor.description = getDocblock(propertyPath) || '';
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = propDocBlockHandler;
|