A node program to generate markdown automatically from js files. Pull requests and Issues are welcome! 😃 🎉
- Getting Started
- Running from command line
- Configuration File
- Configuration File Options
- TAGS used to document the JS Code
- Examples
- Roadmap
First install js-to-markdown globaly:
npm install js-to-markdown --global
After installing js-to-markdown globaly, you can run it directly from the command line with a variety of useful options.
Here's how to js-to-markdown using js-to-markdown.config.js
as a configuration file:
js-to-markdown -c ./js-to-markdown.config.js
Is a JavaScript file
module.exports = {
input: "../path/to/input/dir",
output: "../path/to/output/dir",
subfolders: true,
};
Option. | Default | Required | Description |
---|---|---|---|
input |
none |
yes | Path to the input directory to js files |
output |
none |
yes | Path to the output directory where the markdown files will be created |
subfolders |
true |
no | Search js files in subfolders under input directory |
outputJsMarkdown |
false |
no | If true indicates that the output markdown will be writen as a JS file and an index.js file will be created too |
propTypesToTable |
false |
no | If true generates a table with all file propTypes, if any |
To help in the JS Code documentation it is possible to add some tags
as commentary in your code to generate a more complete markdown output.
All tags must be placed at the beginning of the line as a commentary.
The possible tags
that can be used are:
This tag is used to tell the script to not parse any line of the JS file.
It has to be placed as the first line of the code.
The @CBAll (CB = Code Block) tag indicates that all lines of JS file needs to be parsed inside a markdown code block notation.
The @CBStart and @CBEnd (CB = Code Block) indicates that all lines between the start and the end tag will be parsed inside a markdown code block notation.
React Native Js code example:
//@CBAll
import React from "react";
import { View, Icon, Container, Text } from "react-native";
export default class Welcome extends React.Component {
showApp = (event) => {
const { showApp } = this.props;
event.preventDefault();
if (showApp) {
showApp();
}
};
render() {
return (
<Container>
<View style={styles.mainContent}>
<Icon name="welcome" size={60} customColor={Colors.Yellow} />
<Text h3 style={styles.title}>
JS-TO-MARKDOWN
</Text>
</View>
</Container>
);
}
}
This code generates the Welcome.md
file at output
directory defined in the configuration file with:
import React from \'react\';
import { View, Icon, Container, Text } from \'react-native\';
export default class Welcome extends React.Component {
showApp = (event) => {
const { showApp } = this.props;
event.preventDefault();
if (showApp) {
showApp();
}
};
render() {
return (
<Container>
<View style={styles.mainContent}>
<Icon name=\'welcome\' size={60} customColor={Colors.Yellow} />
<Text h3 style={styles.title}>
JS-TO-MARKDOWN
</Text>
</View>
</Container>
);
}
}
React Native Js code example:
import React from "react";
import { View, Icon, Container, Text } from "react-native";
//# This is the Welcome file
//Exemple code of how to markdown your JS code
//---
export default class Welcome extends React.Component {
//## Function to be called when the aplication starts
//@CBStart
showApp = (event) => {
const { showApp } = this.props;
event.preventDefault();
if (showApp) {
showApp();
}
};
//@CBEnd
//---
//## Render Method
render() {
//@CBStart
return (
<Container>
<View style={styles.mainContent}>
<Icon name="welcome" size={60} customColor={Colors.Yellow} />
<Text h3 style={styles.title}>
JS-TO-MARKDOWN
</Text>
</View>
</Container>
);
//@CBEnd
}
}
This code generates the Welcome.md
file at output
directory defined in the configuration file with:
Exemple code of how to markdown your JS code
showApp = (event) => {
const { showApp } = this.props;
event.preventDefault();
if (showApp) {
showApp();
}
};
return (
<Container>
<View style={styles.mainContent}>
<Icon name=\'welcome\' size={60} customColor={Colors.Yellow} />
<Text h3 style={styles.title}>
JS-TO-MARKDOWN
</Text>
</View>
</Container>
);
To enable the parse of PropTypes declarations into a table inside markdown is necessary to mark the propTypesToTable
flag inside the configuration file as true
React Native Js code example:
import React from "react";
import PropTypes from "prop-types";
import { View, Icon, Container, Text } from "react-native";
//# This is the Welcome file
//Exemple code of how to markdown your JS code
//---
export default class Welcome extends React.Component {
//## Function to be called when the aplication starts
//@CBStart
showApp = (event) => {
const { showApp } = this.props;
event.preventDefault();
if (showApp) {
showApp();
}
};
//@CBEnd
//---
//## Render Method
render() {
//@CBStart
return (
<Container>
<View style={styles.mainContent}>
<Icon name="welcome" size={60} customColor={Colors.Yellow} />
<Text h3 style={styles.title}>
JS-TO-MARKDOWN
</Text>
</View>
</Container>
);
//@CBEnd
}
}
Welcome.defaultProps = {
showApp: () => {},
type: "highlight",
seccondButtonMode: "highlight",
};
Welcome.propTypes = {
/**
* Function to be called on app starts
*/
showApp: PropTypes.func,
/**
* This props enable the account to be removed after process
*/
canRemoveAccount: PropTypes.bool.isRequired,
/**
* Indicates how the info will be presented to user
*/
type: PropTypes.oneOf(["highlight", "opacity", "withoutFeedback"]),
/**
* Object with the params to be presented
*/
params: PropTypes.shape({
documentType: PropTypes.oneOf(DocumentPreviewScreen.DOCUMENT_TYPES)
.isRequired,
buttonMode: PropTypes.oneOf(["highlight", "opacity", "withoutFeedback"])
.isRequired,
resource: PropTypes.string.isRequired,
leftButtonLabel: PropTypes.string,
leftButtonAction: PropTypes.func,
internalParams: PropTypes.shape({
resourceLeftLabel: PropTypes.string.isRequired,
resourceRightLabel: PropTypes.string,
}),
rigthButtonLabel: PropTypes.string,
rigthButtonAction: PropTypes.func,
}),
seccondButtonMode: PropTypes.oneOf([
"highlight",
"opacity",
"withoutFeedback",
]),
documentType: PropTypes.oneOf(DocumentPreviewScreen.DOCUMENT_TYPES),
};
This code generates the Welcome.md
file at output
directory defined in the configuration file with:
Exemple code of how to markdown your JS code
showApp = (event) => {
const { showApp } = this.props;
event.preventDefault();
if (showApp) {
showApp();
}
};
return (
<Container>
<View style={styles.mainContent}>
<Icon name=\'welcome\' size={60} customColor={Colors.Yellow} />
<Text h3 style={styles.title}>
JS-TO-MARKDOWN
</Text>
</View>
</Container>
);
Property | Type | Default | Required | Description |
---|---|---|---|---|
showApp | func | () => {} | false | Function to be called on app starts |
canRemoveAccount | bool | none | true | This props enable the account to be removed after process |
type | enum | 'highlight' | false | One of: [highlight , opacity , withoutFeedback ] - Indicates how the info will be presented to user |
params | object | false | Object with the params to be presented | |
params.documentType | enum | none | true | One of: [DocumentPreviewScreen.DOCUMENT_TYPES] |
params.buttonMode | enum | none | true | One of: [highlight , opacity , withoutFeedback ] |
params.resource | string | none | true | |
params.leftButtonLabel | string | none | false | |
params.leftButtonAction | func | none | false | |
params.internalParams | object | false | ||
params.internalParams.resourceLeftLabel | string | none | true | |
params.internalParams.resourceRightLabel | string | none | false | |
params.rigthButtonLabel | string | none | false | |
params.rigthButtonAction | func | none | false | |
seccondButtonMode | enum | 'highlight' | false | One of: [highlight , opacity , withoutFeedback ] |
documentType | enum | none | false | One of: [DocumentPreviewScreen.DOCUMENT_TYPES] |
- Parse JSDocs tags to markdown;
- Accept other JS extensions (.jsx, .ts, .tsx, ...) to locate and parse files;
- Configuration option to choose if the Markdown file will be saved at output directory or where the original file is;