Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sumnow/markdown-formatter
markdown formatter
https://github.com/sumnow/markdown-formatter
markdown markdown-formatter snippets typescript vscode-extension
Last synced: 3 months ago
JSON representation
markdown formatter
- Host: GitHub
- URL: https://github.com/sumnow/markdown-formatter
- Owner: sumnow
- Created: 2018-11-30T06:04:14.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2023-06-10T01:21:32.000Z (over 1 year ago)
- Last Synced: 2024-08-03T09:13:12.836Z (6 months ago)
- Topics: markdown, markdown-formatter, snippets, typescript, vscode-extension
- Language: TypeScript
- Size: 2.57 MB
- Stars: 116
- Watchers: 1
- Forks: 36
- Open Issues: 35
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
Awesome Lists containing this project
- awesome-github-star - markdown-formatter
README
# markdown-formatter
[中文文档](./README_CN.md)
## Introduction
This is a tool to improve the writing efficiency of markdown, not only provides a relatively uniform format for the `markdown` user, but also provides some snippets.
## Instructions
After the installation is complete, you may need to restart your vscode.
In any `markdown` standard file with a `.md` suffix, you can use `shift+option+f`(Macos) or `ctrl+shift+f`(window) to quickly format the code.
![example.gif](https://raw.githubusercontent.com/sumnow/markdown-formatter/master/images/example.gif)
> PS: It does not fix your markdown syntax errors. for example, there is no space after `#` as a title, because in the code `#` is a usable character that is widely used as a comment or variable declaration.
## Feature
### Ignore file format
If you want to ignore the current file ( not to be formatted ), you can insert below the code before or after the article
```code
```
### Snippets part
**First of all, You must config like this in `settings.json`**
```js
"[markdown]": {
// auto fill
"editor.quickSuggestions": {
"other": true,
"comments": true,
"strings": true
},
}
```#### import image
Typing `img`
![img](./images/example-img.gif)
#### import table
Typing `tab`
![img](./images/example-tab.gif)
#### import code
Typing `js` , `html` , `css` , `python` , `go` , `java` , or `code`
![img](./images/example-code.gif)
#### import list
Typing `ul` or `ol`
![img](./images/example-list.gif)
### Formatter part
#### symbols
* For `,,。;;!、?:` add a space after these symbols;
* `,:;!“”‘’()?。` , unify it as a half-width character(Optional);
* `.!?` add a space after these symbols, if before uppercase letters or chinese;
* Supports converting Chinese symbols into full-width symbols according to context, or converting English into half-width symbols;
* a space before and after the back-quote, which wrapped by back-quote will not be formatted;#### line
* Empty a line for the title;
* Empty a line for the code block;
* The table is aligned automatically;
* Empty a line for the link block;
* erase duplicated line;#### table
![alt](./images/example-tab_format.gif)
#### list
##### unordered list
``` markdown
* TITLE
+ Title
- title```
![alt](./images/example-list_format.gif)
#### code
Format the code, by `js-beautify` tool, currently only the `javascript` , `html` and `css` language;
##### code block
```lang
function sayHello() {console.log('hello')}
```1. If `lang` is `js` or `javascript` or empty, it will be formatted according to js syntax.
2. If `lang` is `html` , it will be formatted according to html syntax.
3. If `lang` is `css` , it will be formatted according to css syntax.
4. If you don't use `js` usually, You can disable code block or code area autoformat code by setting the parameter `formatOpt` to false.> The js formatting rules can be configured in `settings.json` .
> Code blocks can clearly mark the type of language, so it is recommended to use code blocks, you can configure `codeAreaToBlock` to set the conversion method.
##### code area
The default is not formatted. If `codeAreaToBlock` is any language name, such as `js` or `go`, it will be converted into a code block and then formatted.
![img](./images/example-code_area.gif)
**Tips: Empty lines in the code area cannot exceed one line.**
## Config
```js
{
// 是否启用格式化
"markdownFormatter.enable": true,
// 将配置里的全角符号转化为半角符号, 例如 `,:;!“”‘’()?。`
// 当设置为 '_' 或者 '' 的时候, 不转换符号
// 当设置为 'auto' 的时候, 自动根据上下文转换符号
"markdownFormatter.fullWidthTurnHalfWidth": "auto",
// 转换代码块为代码区,默认为''(空字符),不转换
// 可以设置为任意合法英文
// 只有设置成js或者javascript,才会按照js语言语法格式化
"markdownFormatter.codeAreaToBlock": '',
// 是否格式化代码
// false: 不格式化代码
"markdownFormatter.formatCodes" : true,
// 配置js-beautify
// {}: beautifyjs的配置设置
// 配置 `js-beautify` , 可以参考[这里](https://github.com/beautify-web/js-beautify)
"markdownFormatter.formatOpt": {},
// 格式化无序列表的符号
"markdownFormatter.formatULSymbol": true,
// * > + > -
"markdownFormatter.formatULSymbolOpt": {'tag': ["*", "+", "-"]},
// 各种符号后是否需要空格
"markdownFormatter.spaceAfterFullWidthOrHalfWidth": 'half',
// 在文件首部显示时间
"markdownFormatter.displayTime" : false,
// 是否格式化表格
"markdownFormatter.formatTable" : false,
// 代表中文是英文的二倍宽度,用于表格对齐
"markdownFormatter.formatTableOpt" : {'chineseCharterWidth': 2},
}
```How to config `beautifyjs` , you can click[here](https://github.com/beautify-web/js-beautify)
### configuration example
You can refer to my configuration:
```js
// settings.json
// markdown-formatter conf
// Convert the code area of unnamed language into code block according to js type
// "markdownFormatter.codeAreaToBlock": "js",
// or not
"markdownFormatter.codeAreaToBlock": "",
// format punctuation automatically
"markdownFormatter.fullWidthTurnHalfWidth": "auto",
// Chinese punctuation formatted to English
// "markdownFormatter.fullWidthTurnHalfWidth": ",:;!“”‘’()?。",
"markdownFormatter.formatOpt": {
"indent_size": 2
},"markdownFormatter.formatULSymbol": true,
"markdownFormatter.formatULSymbolOpt": {'tag': ["*", "+", "-"]},
"markdownFormatter.formatTable" : true,
// if you use 2-width chinese font, otherwise not set
"markdownFormatter.formatTableOpt" : {'chineseCharterWidth': 2},"[markdown]": {
// auto save
"editor.formatOnSave": false,
// show space
"editor.renderWhitespace": "all",
//
"editor.quickSuggestions": {
"other": true,
"comments": true,
"strings": true
},
//
"editor.snippetSuggestions": "top",
"editor.tabCompletion": "on",
//
"editor.acceptSuggestionOnEnter": "on",
//
"editor.defaultFormatter": "mervin.markdown-formatter"
}
```## Software version and development environment
#### develop version
VSCode version 1.29.1 (macOS Mojave)
#### test version
VSCode version 1.33.1 (macOS Mojave)
## Contact
If you have any ideas, please contact me.
If you know how to format other languages using front-end libraries, please let me know.
email: [email protected] or [here](https://github.com/sumnow/markdown-formatter/issues)
## Gratitude
Thank you for helping me improve this tool.
* [whidy](https://github.com/whidy)
+ Bug(https://github.com/sumnow/markdown-formatter/issues/41)
* [jackfirth](https://github.com/jackfirth)
+ Bug(https://github.com/sumnow/markdown-formatter/issues/35)
* [fruh](https://github.com/fruh)
+ Bug(https://github.com/sumnow/markdown-formatter/issues/36)
* [ddejohn](https://github.com/ddejohn)
+ Bug(https://github.com/sumnow/markdown-formatter/issues/35)
+ Bug(https://github.com/sumnow/markdown-formatter/issues/31)
* [vio1etus](https://github.com/vio1etus)
+ Bug(https://github.com/sumnow/markdown-formatter/issues/29)
* [zybieku](https://github.com/zybieku)
+ Bug(https://github.com/sumnow/markdown-formatter/issues/27)
* [rowild](https://github.com/rowild)
+ Bug(https://github.com/sumnow/markdown-formatter/issues/24)
* [tifDev](https://github.com/tifDev)
+ Bug(https://github.com/sumnow/markdown-formatter/issues/28)
+ Bug(https://github.com/sumnow/markdown-formatter/issues/23)
+ Bug(https://github.com/sumnow/markdown-formatter/issues/22)
* [lartpang](https://github.com/lartpang)
+ Bug(https://github.com/sumnow/markdown-formatter/issues/18)
* [lancerXXXX](https://github.com/lancerXXXX)
+ Bug(https://github.com/sumnow/markdown-formatter/issues/20)
+ Bug(https://github.com/sumnow/markdown-formatter/issues/16)
* [rgeorgiev583](https://github.com/rgeorgiev583)
+ Bug(https://github.com/sumnow/markdown-formatter/issues/14)
* [Ardeshir81](https://github.com/Ardeshir81)
+ Bug(https://github.com/sumnow/markdown-formatter/issues/13)
* [busyrat](https://github.com/busyrat)
+ Feature(https://github.com/sumnow/markdown-formatter/issues/10)
* [lartpang](https://github.com/lartpang)
+ Bug(https://github.com/sumnow/markdown-formatter/issues/15)
+ Feature(https://github.com/sumnow/markdown-formatter/issues/11)
+ Bug(https://github.com/sumnow/markdown-formatter/issues/9)
+ Bug(https://github.com/sumnow/markdown-formatter/issues/8)
+ Bug(https://github.com/sumnow/markdown-formatter/issues/7)
+ Bug(https://github.com/sumnow/markdown-formatter/issues/6)
+ Bug(https://github.com/sumnow/markdown-formatter/issues/5)
* [iostalks](https://github.com/iostalks)
+ Feature(https://github.com/sumnow/markdown-formatter/issues/3)
* [zhuoyan](https://github.com/zhuoyan)
+ Bug(https://github.com/sumnow/markdown-formatter/issues/1)> Sorting only according to the time of the question