Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hmsk/vite-plugin-markdown
A vite plugin to import a Markdown file in various formats like Front Matter, HTML, ToC, and React/Vue Component
https://github.com/hmsk/vite-plugin-markdown
frontmatter markdown markdown-it react vite vue
Last synced: 5 days ago
JSON representation
A vite plugin to import a Markdown file in various formats like Front Matter, HTML, ToC, and React/Vue Component
- Host: GitHub
- URL: https://github.com/hmsk/vite-plugin-markdown
- Owner: hmsk
- License: mit
- Created: 2020-07-01T07:37:30.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2025-01-06T19:12:32.000Z (15 days ago)
- Last Synced: 2025-01-11T04:53:16.716Z (11 days ago)
- Topics: frontmatter, markdown, markdown-it, react, vite, vue
- Language: TypeScript
- Homepage: https://www.npmjs.com/package/vite-plugin-markdown
- Size: 2.1 MB
- Stars: 266
- Watchers: 3
- Forks: 45
- Open Issues: 25
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# vite-plugin-markdown
[![npm](https://img.shields.io/npm/v/vite-plugin-markdown.svg?style=for-the-badge)](https://www.npmjs.com/package/vite-plugin-markdown) [![npm beta channel](https://img.shields.io/npm/v/vite-plugin-markdown/beta?style=for-the-badge&label=beta&color=yellow)](https://www.npmjs.com/package/vite-plugin-markdown/v/beta)
A plugin enables you to import a Markdown file as various formats on your [vite](https://github.com/vitejs/vite) project.
## Setup
```
npm i -D vite-plugin-markdown
```For vite v1
```
npm i -D vite-plugin-markdown@vite-1
```### Config
```js
import mdPlugin from 'vite-plugin-markdown'module.exports = {
plugins: [mdPlugin(options)]
}
```Then you can import front matter attributes from `.md` file as default.
```md
---
title: Awesome Title
description: Describe this awesome content
tags:
- "great"
- "awesome"
- "rad"
---# This is awesome
Vite is an opinionated web dev build tool that serves your code via native ES Module imports during dev and bundles it with Rollup for production.
``````ts
import { attributes } from './contents/the-doc.md';console.log(attributes) //=> { title: 'Awesome Title', description: 'Describe this awesome content', tags: ['great', 'awesome', 'rad'] }
```### Options
```ts
mode?: ('html' | 'markdown' | 'toc' | 'react' | 'vue')[]
markdown?: (body: string) => string
markdownIt?: MarkdownIt | MarkdownIt.Options
```Enum for `mode` is provided as `Mode`
```ts
import { Mode } from 'vite-plugin-markdown'console.log(Mode.HTML) //=> 'html'
console.log(Mode.MARKDOWN) //=> 'markdown'
console.log(Mode.TOC) //=> 'toc'
console.log(Mode.REACT) //=> 'react'
console.log(Mode.VUE) //=> 'vue'
```"Mode" enables you to import markdown file in various formats (HTML, ToC, React/Vue Component)
#### `Mode.HTML`
Import compiled HTML
```md
# This is awesomeVite is an opinionated web dev build tool that serves your code via native ES Module imports during dev and bundles it with Rollup for production.
``````ts
import { html } from './contents/the-doc.md';console.log(html) //=> "
This is awesome
ite is an opinionated web dev build tool that serves your code via native ES Module imports during dev and bundles it with Rollup for production.
"
```#### `Mode.MARKDOWN`
Import the raw Markdown content
```js
import { markdown } from './contents/the-doc.md'console.log(markdown) //=> "# This is awesome \n Vite is an opinionated web dev build tool that serves your code via native ES Module imports during dev and bundles it with Rollup for production."
```#### `Mode.TOC`
Import ToC metadata
```md
# viteVite is an opinionated web dev build tool that serves your code via native ES Module imports during dev and bundles it with Rollup for production.
## Status
## Getting Started
# Notes
``````ts
import { toc } from './contents/the-doc.md'console.log(toc) //=> [{ level: '1', content: 'vite' }, { level: '2', content: 'Status' }, { level: '2', content: 'Getting Started' }, { level: '1', content: 'Notes' },]
```#### `Mode.REACT`
Import as a React component
```jsx
import React from 'react'
import { ReactComponent } from './contents/the-doc.md'function MyReactApp() {
return (
}
```Custom Element on a markdown file can be runnable as a React component as well
```md
# This is awesomeVite is
``````jsx
import React from 'react'
import { ReactComponent } from './contents/the-doc.md'
import { MyComponent } from './my-component'function MyReactApp() {
return (
}
````MyComponent` on markdown perform as a React component.
#### `Mode.VUE`
Import as a Vue component
```vue
import { VueComponent } from './contents/the-doc.md'
export default {
components: {
MarkdownContent: VueComponent
}
};```
Custom Element on a markdown file can be runnable as a Vue component as well
```md
# This is awesomeVite is
``````vue
import { VueComponentWith } from './contents/the-doc.md'
import MyComponent from './my-component.vue'export default {
components: {
MarkdownContent: VueComponentWith({ MyComponent })
}
};```
`MyComponent` on markdown perform as a Vue component.
### Type declarations
In TypeScript project, need to declare typedefs for `.md` file as you need.
```ts
declare module '*.md' {
// "unknown" would be more detailed depends on how you structure frontmatter
const attributes: Record;// When "Mode.TOC" is requested
const toc: { level: string, content: string }[];// When "Mode.HTML" is requested
const html: string;// When "Mode.RAW" is requested
const raw: string// When "Mode.React" is requested. VFC could take a generic like React.VFC<{ MyComponent: TypeOfMyComponent }>
import React from 'react'
const ReactComponent: React.VFC;
// When "Mode.Vue" is requested
import { ComponentOptions, Component } from 'vue';
const VueComponent: ComponentOptions;
const VueComponentWith: (components: Record) => ComponentOptions;// Modify below per your usage
export { attributes, toc, html, ReactComponent, VueComponent, VueComponentWith };
}
```Save as `vite.d.ts` for instance.
## License
MIT