Skip to content

Plugin to create list with custom markers. The item list can be divided by a string or an array of strings.

Notifications You must be signed in to change notification settings

moudev/markdown-it-list-marker

Repository files navigation

markdown-it-list-marker

markdown-it plugin to create lists with custom markers.

How to use it?

const mdMarkerPlugin = require("markdown-it-list-marker")

module.exports = {
  ...,
  extendsMarkdown: (md) => {
    md.use(mdMarkerPlugin)
  },
};

Configure the marker

To add the custom marker the plugin finds a pattern in the text of the markdown item. Each markdown item that matches the text pattern will have a custom marker.

markerSeparator is the plugin option to set. The plugin option can be a string or an array of strings, which means that the plugin can find multiple patterns. The default value of markerSeparator is the string -.

Warning: markdown-it recognize the string ")" to add an ordered element so make sure to use a different pattern.

CSS style

When the list contains one item that matches the pattern a CSS class will be added to the item and the parent of the list. Also will be added a class for the marker and the text of the item.

  • <ul> -> md-it-list-marker__list class
  • <li> -> md-it-list-marker__item class
  • <span> marker -> md-it-list-marker__marker class
  • <span> text -> md-it-list-marker__text class

You can use the CSS style that you want but there is a proposal of style to simulate the markers of the default <ul> HTML:

li.md-it-list-marker__item {
  position: relative;
}

span.md-it-list-marker__marker {
  position: absolute;
  height: 27.1875px;
  width: 8px;
  display: flex;
  justify-content: flex-end;
  white-space: nowrap;
  left: -17px;
}

span.md-it-list-marker__text {
  text-align: left;
}

The style can be added from the index.css and added directly to the style of your project. The second option is to add a <link> tag in the <head> of the index.html and set the src attribute with https://cdn.jsdelivr.net/npm/markdown-it-list-marker/index.css

Example

Config file:

const mdMarkerPlugin = require("markdown-it-list-marker")

module.exports = {
  ...,
  extendsMarkdown: (md) => {
    md.use(mdMarkerPlugin)
    md.set({ markerSeparator: ["_", "-", "%", "$"] }) // default value "-"
  },
};

Markdown text:

# demo

- 11_ demo
- 12- demo
- 13% demo
- 14$ demo

HTML result:

<h1>demo</h1>
<ul class="md-it-list-marker__list">
  <li class="md-it-list-marker__item">
    <span class="md-it-list-marker__marker">11_</span>
    <span class="md-it-list-marker__text">demo</span>
  </li>
  <li class="md-it-list-marker__item">
    <span class="md-it-list-marker__marker">12-</span>
    <span class="md-it-list-marker__text">demo</span>
  </li>
  <li class="md-it-list-marker__item">
    <span class="md-it-list-marker__marker">13%</span>
    <span class="md-it-list-marker__text">demo</span>
  </li>
  <li class="md-it-list-marker__item">
    <span class="md-it-list-marker__marker">14$</span>
    <span class="md-it-list-marker__text">demo</span>
  </li>
</ul>

More examples:

You can check test/index.test.js.

Prerequisites for development

Project setup for development

1. Install dependencies

yarn install

2. Config Git hooks (required)

yarn prepare

Development mode

yalc is used to publish the package locally and be able to test it. The command will do the build process and push the build to the local projects where the package has been added.

yarn dev:yalc

Test

yarn test:run

Build mode

yarn build