Skip to content
This repository has been archived by the owner on Dec 18, 2024. It is now read-only.
/ bimark Public archive

Auto create bidirectional links between markdown files.

License

Notifications You must be signed in to change notification settings

DiscreteTom/bimark

Repository files navigation

[[BiMark]]

npm license

Auto create [[bidirectional links]] between markdown files.

Installation

For API usage:

npm install bimark

Other usages:

Usage

Basic

Create definitions in markdown documents with [[name]]:

# [[BiMark]]

BiMark is a tool to auto create [[bidirectional links]] between markdown files.

Once bidirectional links are created, you can use it to navigate between markdown files.

In the above example, BiMark and bidirectional links are definitions.

After rendering, all definitions and references will be modified to add an id, and all references will be automatically replaced with links:

# <span id="bimark">BiMark</span>

[<span id="bimark-ref-1">BiMark</span>](#bimark) is a tool to auto create <span id="bidirectional-links">bidirectional links</span> between markdown files.

Once the [<span id="bidirectional-links-ref-1">bidirectional links</span>](#bidirectional-links) is created, you can use it to navigate between markdown files.

Explicit Reference

You can create references explicitly using [[#id]] or [[@name]]:

# [[BiMark]]

[[#bimark]] is a tool to auto create [[bidirectional links]] between markdown files.

Once the [[@bidirectional links]] is created, you can use it to navigate between markdown files.

Advanced Definition

  • You can use [[name:id]] to specify the id of the definition.
  • If there are aliases for a definition, you can use [[name|alias1|alias2]].
    • If you don't specify the id, the name will be used to calculate the id.
# [[BiMark|bi-mark|bimark]]

# [[BiMark|bi-mark|bimark:bimark]]

Escaped Reference

You can escape a reference using [[!any string]]:

# [[BiMark]]

[[!BiMark]] is a tool to auto create [[bidirectional link]] between markdown files.

The escaped reference will not check if the definition exists, not be replaced with a link, and will not be assigned with an id.

API

import { BiMark } from "bimark";

// collect from and render a single file, return the rendered content
BiMark.singleFile("# [[BiMark]]");

// collect definitions
const bm = new BiMark().collect("file1.md", content1);

// render files
bm.render("file1.md", content1);
bm.render("file2.md", content2);

// list reverse links
bm.getReverseRefs({ name: "BiMark" }); // => ['file1.md#bimark-ref-1', 'file2.md#bimark-ref-2']

BiML

You can also use BiML to parse and render HTML documents, the APIs are almost the same as BiMark.

import { BiML } from "bimark";

// collect from and render a single file, return the rendered content
BiML.singleFile("<p>[[BiML]]</p>");

// collect definitions
const bm = new BiML().collect("file1.html", content1);

// render files
bm.render("file1.html", content1);
bm.render("file2.html", content2);

// list reverse links
bm.getReverseRefs({ name: "BiML" }); // => ['file1.html#biml-ref-1', 'file2.html#biml-ref-2']

Extensibility

BiMark provides low-level classes BiDoc/BiParser for you:

  • BiDoc is the base class of BiMark/BiML. You can extend this class to parse other file types.
  • BiParser is the low level parser to parse text string to Fragment for further processing.

FAQ

  • Where can I make a definition/reference?
    • For markdown, texts(e.g. headings, paragraphs, lists).
    • For HTML, you can customize this by passing selectors options to BiML.collect/render.
  • How to solve the problem of duplicate ids?
    • You can use [[name:id]] to specify the id of a definition.
  • What characters are allowed in the name/alias of a definition?
    • Regex: [^$&+,/:;=?!@"'<>#%{}|\\^~[\]`\n\r].
    • Yes, spaces are allowed.
    • Language specific characters are allowed, e.g. [[中文]] is allowed.
  • What characters are allowed in the id of a definition?
    • Regex: [^$&+,/:;=?!@ "'<>#%{}|\\^~[\]`\n\r].
    • No, spaces are not allowed.
  • What characters are allowed in the escaped reference?
    • Regex: .*?

About

Auto create bidirectional links between markdown files.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published