react-markdown-loader
Version:
Webpack loader to render React Components from markdown
126 lines (96 loc) • 3.42 kB
Markdown
React Markdown
==================
[![Build Status][badge-ci]][url-ci]
[![Known Vulnerabilities][badge-sec]][url-sec]
[![npm version][badge-version]][url-version]
[![npm downloads][badge-downloads]][url-downloads]
[![Dependency Status][badge-deps]][url-deps]
[![peerDependency Status][badge-deps-peer]][url-deps-peer]
[![devDependency Status][badge-deps-dev]][url-deps-dev]
[badge-ci]: https://travis-ci.org/javiercf/react-markdown-loader.svg?branch=master
[badge-sec]: https://snyk.io/test/github/javiercf/react-markdown-loader/badge.svg?targetFile=package.json
[badge-version]: https://img.shields.io/npm/v/react-markdown-loader.svg
[badge-downloads]: https://img.shields.io/npm/dm/react-markdown-loader.svg
[badge-deps]: https://david-dm.org/javiercf/react-markdown-loader/status.svg
[badge-deps-dev]: https://david-dm.org/javiercf/react-markdown-loader/dev-status.svg
[url-ci]: https://travis-ci.org/javiercf/react-markdown-loader "Build Status"
[url-sec]: https://snyk.io/test/github/javiercf/react-markdown-loader?targetFile=package.json "Known Vulnerabilities"
[url-version]: https://www.npmjs.com/package/react-markdown-loader "npm version"
[url-downloads]: https://www.npmjs.com/package/react-markdown-loader "npm downloads"
[url-deps]: https://david-dm.org/javiercf/react-markdown-loader "Dependency Status"
[url-deps-dev]: https://david-dm.org/javiercf/react-markdown-loader?type=dev "Dev Dependency Status"
Webpack loader that parses markdown files and converts them to a React Stateless Component.
It will also parse FrontMatter to import dependencies and render components
along with it’s source code.
We developed this loader to make the process of creating styleguides for
React components easier.
## Usage
In the FrontMatter you should import the components you want to render
with the component name as a key and it's path as the value
```markdown
---
imports:
HelloWorld: './hello-world.js',
'{ Component1, Component2 }': './components.js'
---
```
*webpack.config.js*
```js
module: {
loaders: [
{
test: /\.md$/,
loader: 'babel!react-markdown'
}
]
}
```
*hello-world.js*
```js
import React, { PropTypes } from 'react';
/**
* HelloWorld
* @param {Object} props React props
* @returns {JSX} template
*/
export default function HelloWorld(props) {
return (
<div className="hello-world">
Hello { props.who }
</div>
);
}
HelloWorld.propTypes = {
who: PropTypes.string
};
HelloWorld.defaultProps = {
who: 'World'
};
```
In the markdown File add the *render* tag to code fenceblocks you want the
loader to compile as Components this will output the usual highlighted code
and the rendered component.
*hello-world.md*
<pre>
---
imports:
HelloWorld: './hello-world.js'
---
# Hello World
This is an example component
```render html
<HelloWorld />
```
You can send who to say Hello
```render html
<HelloWorld who="World!!!" />
```
</pre>
## Contributing
Pull requests and stars are always welcome. For bugs and feature requests, [please create an issue](../../issues/new).
## Team
[](https://github.com/javiercf) | [](https://fernandopasik.com)
---|---
[Javier Cubides](https://github.com/javiercf) | [Fernando Pasik](https://fernandopasik.com)
## License
MIT (c) 2017