2015-03-23 10:55:49 -07:00
|
|
|
/**
|
|
|
|
* Copyright (c) 2015-present, 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.
|
|
|
|
*/
|
|
|
|
|
2015-03-19 14:05:07 -07:00
|
|
|
var docgen = require('react-docgen');
|
|
|
|
var docgenHelpers = require('./docgenHelpers');
|
2015-02-12 14:43:41 -08:00
|
|
|
var fs = require('fs');
|
|
|
|
var path = require('path');
|
|
|
|
var slugify = require('../core/slugify');
|
2015-03-13 15:30:31 -07:00
|
|
|
var jsDocs = require('../jsdocs/jsdocs.js');
|
2015-02-12 14:43:41 -08:00
|
|
|
|
|
|
|
function getNameFromPath(filepath) {
|
|
|
|
var ext = null;
|
|
|
|
while (ext = path.extname(filepath)) {
|
|
|
|
filepath = path.basename(filepath, ext);
|
|
|
|
}
|
2015-03-23 15:22:47 -07:00
|
|
|
if (filepath === 'LayoutPropTypes') {
|
|
|
|
return 'Flexbox';
|
2015-04-21 10:19:36 -07:00
|
|
|
} else if (filepath == 'TabBarItemIOS') {
|
|
|
|
return 'TabBarIOS.Item';
|
2015-03-23 15:22:47 -07:00
|
|
|
}
|
2015-02-12 14:43:41 -08:00
|
|
|
return filepath;
|
|
|
|
}
|
|
|
|
|
2015-03-31 12:28:26 -07:00
|
|
|
function getExample(componentName) {
|
|
|
|
var path = '../Examples/UIExplorer/' + componentName + 'Example.js';
|
|
|
|
if (!fs.existsSync(path)) {
|
2015-03-31 14:05:15 -07:00
|
|
|
path = '../Examples/UIExplorer/' + componentName + 'Example.ios.js';
|
|
|
|
if (!fs.existsSync(path)) {
|
|
|
|
return;
|
|
|
|
}
|
2015-03-31 12:28:26 -07:00
|
|
|
}
|
|
|
|
return {
|
2015-03-31 12:31:37 -07:00
|
|
|
path: path.replace(/^\.\.\//, ''),
|
2015-03-31 12:28:26 -07:00
|
|
|
content: fs.readFileSync(path).toString(),
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2015-03-19 14:05:07 -07:00
|
|
|
function componentsToMarkdown(type, json, filepath, i, styles) {
|
2015-02-12 14:43:41 -08:00
|
|
|
var componentName = getNameFromPath(filepath);
|
|
|
|
|
2015-03-04 21:03:24 -08:00
|
|
|
var docFilePath = '../docs/' + componentName + '.md';
|
|
|
|
if (fs.existsSync(docFilePath)) {
|
|
|
|
json.fullDescription = fs.readFileSync(docFilePath).toString();
|
|
|
|
}
|
2015-03-12 11:03:32 -07:00
|
|
|
json.type = type;
|
2015-03-31 10:10:05 -07:00
|
|
|
json.filepath = filepath.replace(/^\.\.\//, '');
|
|
|
|
json.componentName = componentName;
|
2015-03-19 14:05:07 -07:00
|
|
|
if (styles) {
|
|
|
|
json.styles = styles;
|
|
|
|
}
|
2015-03-31 12:28:26 -07:00
|
|
|
json.example = getExample(componentName);
|
2015-03-04 21:03:24 -08:00
|
|
|
|
2015-02-12 14:43:41 -08:00
|
|
|
var res = [
|
|
|
|
'---',
|
|
|
|
'id: ' + slugify(componentName),
|
|
|
|
'title: ' + componentName,
|
2015-03-04 18:10:12 -08:00
|
|
|
'layout: autodocs',
|
2015-03-23 15:22:47 -07:00
|
|
|
'category: ' + (type === 'style' ? 'Polyfills' : type + 's'),
|
2015-02-12 14:43:41 -08:00
|
|
|
'permalink: docs/' + slugify(componentName) + '.html',
|
2015-03-21 10:59:41 -07:00
|
|
|
'next: ' + (all[i + 1] ?
|
|
|
|
slugify(getNameFromPath(all[i + 1])) :
|
|
|
|
'network'),
|
2015-02-12 14:43:41 -08:00
|
|
|
'---',
|
2015-03-04 18:10:12 -08:00
|
|
|
JSON.stringify(json, null, 2),
|
2015-02-12 14:43:41 -08:00
|
|
|
].filter(function(line) { return line; }).join('\n');
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
2015-03-24 21:13:55 -07:00
|
|
|
var n;
|
|
|
|
|
|
|
|
function renderComponent(filepath) {
|
|
|
|
var json = docgen.parse(
|
|
|
|
fs.readFileSync(filepath),
|
|
|
|
docgenHelpers.findExportedOrFirst,
|
|
|
|
docgen.defaultHandlers.concat(docgenHelpers.stylePropTypeHandler)
|
|
|
|
);
|
|
|
|
return componentsToMarkdown('component', json, filepath, n++, styleDocs);
|
|
|
|
}
|
|
|
|
|
|
|
|
function renderAPI(type) {
|
|
|
|
return function(filepath) {
|
|
|
|
var json;
|
|
|
|
try {
|
|
|
|
json = jsDocs(fs.readFileSync(filepath).toString());
|
|
|
|
} catch(e) {
|
|
|
|
console.error('Cannot parse file', filepath);
|
|
|
|
json = {};
|
|
|
|
}
|
|
|
|
return componentsToMarkdown(type, json, filepath, n++);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
function renderStyle(filepath) {
|
|
|
|
var json = docgen.parse(
|
|
|
|
fs.readFileSync(filepath),
|
|
|
|
docgenHelpers.findExportedObject,
|
|
|
|
[docgen.handlers.propTypeHandler]
|
|
|
|
);
|
|
|
|
return componentsToMarkdown('style', json, filepath, n++);
|
|
|
|
}
|
|
|
|
|
2015-02-12 14:43:41 -08:00
|
|
|
var components = [
|
2015-03-04 21:03:24 -08:00
|
|
|
'../Libraries/Components/ActivityIndicatorIOS/ActivityIndicatorIOS.ios.js',
|
2015-03-10 13:55:54 -07:00
|
|
|
'../Libraries/Components/DatePicker/DatePickerIOS.ios.js',
|
2015-03-02 17:31:26 -08:00
|
|
|
'../Libraries/Image/Image.ios.js',
|
2015-03-21 10:07:45 -07:00
|
|
|
'../Libraries/CustomComponents/ListView/ListView.js',
|
2015-03-13 15:30:31 -07:00
|
|
|
'../Libraries/Components/MapView/MapView.js',
|
2015-03-26 06:43:45 -07:00
|
|
|
'../Libraries/CustomComponents/Navigator/Navigator.js',
|
2015-02-12 14:43:41 -08:00
|
|
|
'../Libraries/Components/Navigation/NavigatorIOS.ios.js',
|
2015-03-13 15:30:31 -07:00
|
|
|
'../Libraries/Picker/PickerIOS.ios.js',
|
2015-03-09 11:49:58 -07:00
|
|
|
'../Libraries/Components/ScrollView/ScrollView.js',
|
2015-03-19 13:55:42 -07:00
|
|
|
'../Libraries/Components/SliderIOS/SliderIOS.js',
|
2015-03-10 13:55:54 -07:00
|
|
|
'../Libraries/Components/SwitchIOS/SwitchIOS.ios.js',
|
|
|
|
'../Libraries/Components/TabBarIOS/TabBarIOS.ios.js',
|
2015-04-21 10:19:36 -07:00
|
|
|
'../Libraries/Components/TabBarIOS/TabBarItemIOS.ios.js',
|
2015-03-02 17:31:26 -08:00
|
|
|
'../Libraries/Text/Text.js',
|
2015-03-31 09:46:45 -07:00
|
|
|
'../Libraries/Components/TextInput/TextInput.js',
|
2015-02-12 14:43:41 -08:00
|
|
|
'../Libraries/Components/Touchable/TouchableHighlight.js',
|
2015-03-04 21:03:24 -08:00
|
|
|
'../Libraries/Components/Touchable/TouchableOpacity.js',
|
2015-02-12 14:43:41 -08:00
|
|
|
'../Libraries/Components/Touchable/TouchableWithoutFeedback.js',
|
2015-02-18 16:39:28 -08:00
|
|
|
'../Libraries/Components/View/View.js',
|
2015-03-17 20:41:06 -07:00
|
|
|
'../Libraries/Components/WebView/WebView.ios.js',
|
2015-02-12 14:43:41 -08:00
|
|
|
];
|
|
|
|
|
2015-03-10 13:55:54 -07:00
|
|
|
var apis = [
|
2015-03-17 20:41:06 -07:00
|
|
|
'../Libraries/Utilities/AlertIOS.js',
|
2015-03-13 15:30:31 -07:00
|
|
|
'../Libraries/AppRegistry/AppRegistry.js',
|
|
|
|
'../Libraries/AppStateIOS/AppStateIOS.ios.js',
|
|
|
|
'../Libraries/Storage/AsyncStorage.ios.js',
|
2015-03-12 11:03:32 -07:00
|
|
|
'../Libraries/CameraRoll/CameraRoll.js',
|
2015-03-17 20:41:06 -07:00
|
|
|
'../Libraries/Interaction/InteractionManager.js',
|
2015-03-12 11:03:32 -07:00
|
|
|
'../Libraries/Animation/LayoutAnimation.js',
|
2015-03-26 16:32:35 +00:00
|
|
|
'../Libraries/LinkingIOS/LinkingIOS.js',
|
2015-03-17 20:41:06 -07:00
|
|
|
'../Libraries/Network/NetInfo.js',
|
2015-03-24 20:38:29 -07:00
|
|
|
'../Libraries/vendor/react/browser/eventPlugins/PanResponder.js',
|
2015-03-12 11:03:32 -07:00
|
|
|
'../Libraries/Utilities/PixelRatio.js',
|
2015-03-24 20:38:29 -07:00
|
|
|
'../Libraries/PushNotificationIOS/PushNotificationIOS.js',
|
2015-03-12 11:03:32 -07:00
|
|
|
'../Libraries/Components/StatusBar/StatusBarIOS.ios.js',
|
|
|
|
'../Libraries/StyleSheet/StyleSheet.js',
|
2015-03-17 20:41:06 -07:00
|
|
|
'../Libraries/Vibration/VibrationIOS.ios.js',
|
2015-03-10 13:55:54 -07:00
|
|
|
];
|
|
|
|
|
2015-03-19 14:05:07 -07:00
|
|
|
var styles = [
|
|
|
|
'../Libraries/StyleSheet/LayoutPropTypes.js',
|
|
|
|
'../Libraries/Components/View/ViewStylePropTypes.js',
|
|
|
|
'../Libraries/Text/TextStylePropTypes.js',
|
|
|
|
'../Libraries/Image/ImageStylePropTypes.js',
|
|
|
|
];
|
|
|
|
|
2015-03-24 21:13:55 -07:00
|
|
|
var polyfills = [
|
2015-04-24 13:14:24 -07:00
|
|
|
'../Libraries/GeoLocation/Geolocation.js',
|
2015-03-24 21:13:55 -07:00
|
|
|
];
|
|
|
|
|
|
|
|
var all = components
|
|
|
|
.concat(apis)
|
|
|
|
.concat(styles.slice(0, 1))
|
|
|
|
.concat(polyfills);
|
|
|
|
|
2015-03-19 14:05:07 -07:00
|
|
|
var styleDocs = styles.slice(1).reduce(function(docs, filepath) {
|
|
|
|
docs[path.basename(filepath).replace(path.extname(filepath), '')] =
|
|
|
|
docgen.parse(
|
|
|
|
fs.readFileSync(filepath),
|
|
|
|
docgenHelpers.findExportedObject,
|
|
|
|
[docgen.handlers.propTypeHandler]
|
|
|
|
);
|
|
|
|
return docs;
|
|
|
|
}, {});
|
2015-03-12 11:03:32 -07:00
|
|
|
|
2015-02-12 14:43:41 -08:00
|
|
|
module.exports = function() {
|
2015-03-24 21:13:55 -07:00
|
|
|
n = 0;
|
2015-03-12 11:03:32 -07:00
|
|
|
return [].concat(
|
2015-03-24 21:13:55 -07:00
|
|
|
components.map(renderComponent),
|
|
|
|
apis.map(renderAPI('api')),
|
|
|
|
styles.slice(0, 1).map(renderStyle),
|
|
|
|
polyfills.map(renderAPI('Polyfill'))
|
2015-03-12 11:03:32 -07:00
|
|
|
);
|
2015-02-12 14:43:41 -08:00
|
|
|
};
|