Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/geekplux/markvis
make visualization in markdown. ๐๐
https://github.com/geekplux/markvis
chart d3 d3-node markdown markdown-editor markdown-it markdown-it-plugin markdown-to-html visual visualization visualizer
Last synced: about 23 hours ago
JSON representation
make visualization in markdown. ๐๐
- Host: GitHub
- URL: https://github.com/geekplux/markvis
- Owner: geekplux
- License: mit
- Created: 2017-07-02T03:04:42.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2023-09-16T03:32:07.000Z (over 1 year ago)
- Last Synced: 2025-01-03T15:07:25.560Z (8 days ago)
- Topics: chart, d3, d3-node, markdown, markdown-editor, markdown-it, markdown-it-plugin, markdown-to-html, visual, visualization, visualizer
- Language: JavaScript
- Homepage: https://markvis.js.org/
- Size: 571 KB
- Stars: 1,573
- Watchers: 26
- Forks: 61
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- keep-it-txt - markvis
- project-awesome - geekplux/markvis - make visualization in markdown. ๐๐ (JavaScript)
- awesome-repositories - geekplux/markvis - make visualization in markdown. ๐๐ (JavaScript)
- awesome-list - markvis
- awesome-starred - geekplux/markvis - make visualization in markdown. ๐๐ (markdown)
README
# Markvis
> Make visualization in markdown.
[![NPM version](https://img.shields.io/npm/v/markvis.svg?style=flat-square)](https://npmjs.com/package/markvis) [![NPM downloads](https://img.shields.io/npm/dm/markvis.svg?style=flat-square)](https://npmjs.com/package/markvis) [![Build](https://travis-ci.org/geekplux/markvis.svg?style=flat-square)](https://travis-ci.org/geekplux/markvis) [![Coverage](https://coveralls.io/repos/github/geekplux/markvis/badge.svg?style=flat-square)](https://coveralls.io/github/geekplux/markvis) [![donate](https://img.shields.io/badge/$-donate-ff69b4.svg?maxAge=2592000&style=flat-square)](https://geekplux.github.io/donate)
[![FOSSA Status](https://app.fossa.io/api/projects/git%2Bhttps%3A%2F%2Fgithub.com%2Fgeekplux%2Fmarkvis.svg?type=shield)](https://app.fossa.io/projects/git%2Bhttps%3A%2F%2Fgithub.com%2Fgeekplux%2Fmarkvis?ref=badge_shield)- [Documentation](https://markvis.js.org)
- [Online Editor](https://markvis-editor.js.org)## Preview
![](./docs/preview.png)
# Quick Start
## Install
```bash
yarn add markvis --save
npm install markvis --save
```## Usage
```js
const md = require('markdown-it')()
const vis = require('markvis')
const d3 = require('d3') // in browser environment
const d3node = require('d3-node') // in node environmentmd.use(vis).render(`
your markdown content
`, {
d3, // in browser environment
d3node // in node environment
})
```there are [Examples](https://github.com/geekplux/markvis/tree/master/examples) which in node environment.
# Motivation
We often publish articles enriched with data, since data make them more convincing and easy to interpret. Hence, techniques that enable the embedding of visualization into texts are of great importance.
However, the most frequently used method now is to export charts as images, upload them into cloud, and then paste them into the editor. It is a tedious process from the perspective of a writer. Besides, image loading costs much more time than that of DOM elements, which leads to poor experience from the perspective of a reader.
# API
There are many options you can config and below is some in common. But you'd better to config the options which related to chart style in chart options, such as [markvis-bar](https://github.com/geekplux/markvis-bar), [markvis-line](https://github.com/geekplux/markvis-line), [markvis-pie](https://github.com/geekplux/markvis-pie).
## options
##### data
- Type: `Array`
Data from file or web processed by d3 library.
##### d3
- Type: `Object`
[d3](https://github.com/d3/d3) library which used in **browser** environment.
##### d3node
- Type: `Function`
[d3-node](https://github.com/d3-node/d3-node) constructor which used in **node** environment.
##### layout
- Type: `String`
Name of chart layout. You can customize any chart layout you want.
##### render
- Type: `Function`
Customized renderer to render a new layout you want.
##### container
- Type: `String`
- Default: ``Bar Chart
DOM contained the visualization result.
##### selector
- Type: `String`
- Default: `'#chart'`DOM selector in container.
##### style
- Type: `String`
- Default: `''`Chart style.
##### width
- Type: `Number`
- Default: `960`SVG width for chart.
##### height
- Type: `Number`
- Default: `500`SVG height for chart.
##### margin
- Type: `Object`
- Default: `{ top: 20, right: 20, bottom: 20, left: 20 }`Margin of the first wrapper in SVG, usually used to add axis.
# Contributing
1. Fork it!
2. Create your feature branch: `git checkout -b my-new-feature`
3. Commit your changes: `git commit -am 'Add some feature'`
4. Push to the branch: `git push origin my-new-feature`
5. Submit a pull request :D# LICENSE
**markvis** ยฉ [geekplux](https://github.com/geekplux), Released under the [MIT](./LICENSE) License.
Authored and maintained by geekplux with help from contributors ([list](https://github.com/geekplux/markvis/contributors)).> [geekplux.com](http://geekplux.com) ยท GitHub [@geekplux](https://github.com/geekplux) ยท Twitter [@geekplux](https://twitter.com/geekplux)
[![FOSSA Status](https://app.fossa.io/api/projects/git%2Bhttps%3A%2F%2Fgithub.com%2Fgeekplux%2Fmarkvis.svg?type=large)](https://app.fossa.io/projects/git%2Bhttps%3A%2F%2Fgithub.com%2Fgeekplux%2Fmarkvis?ref=badge_large)