nonplain-md-link
Tools for markdown links in nonplain files.
What this library does
Markdown files often contain markdown-style links, which look like this:
[link inner text](/path/to/some/file/or/site)
They can also sometimes contain wiki-style links when used for notetaking. Wiki-style links look like this:
[[/path/to/some/file/or/site]]
The concept: provide a tool for gathering and working with markdown and wiki-style links within nonplain files.
Once these links are gathered, they can be analyzed and selectively edited to accomplish various goals such as:
- converting links to HTML
- re-basing links to work on your personal website
- listing all forward links in a file
- calculating backlinks for a file
...and more.
API
Initialization
To parse a link, pass it as a string to the Link
class upon initialization:
const Link = require("nonplain-md-link").default;
const markdownLink = new Link('[my markdown link](/path/to/file.md)');
const wikiLink = new Link('[[/path/to/file.md]]');
console.log(markdownLink);
// Output:
//
// {
// "initialStyle": "markdown",
// "innerText": "my markdown link",
// "path": "/path/to/file.md",
// }
console.log(wikiLink);
// Output:
//
// {
// "initialStyle": "wiki",
// "innerText": "/path/to/file.md",
// "path": "/path/to/file.md",
// }
Once a link is parsed, its contents can be used to construct new links.
Link.collectAllLinksFromContent()
Returns Link
instances for all markdown and wiki-style links within a given string.
const Link = require("nonplain-md-link").default;
const { File } = require("nonplain");
const file = new File().load('/path/to/file.md');
const linksInFileBody = Link.collectAllLinksFromContent(file.body);
console.log(linksInFileBody);
// Output:
//
// [
// {
// "initialStyle": "markdown",
// "innerText": "as discussed in class",
// "path": "../notes/CS231n notes.md"
// },
// {
// "initialStyle": "markdown",
// "innerText": "descending the loss gradient",
// "path": "https://en.wikipedia.org/wiki/Gradient_descent"
// },
// {
// "initialStyle": "wiki",
// "innerText": "How to backpropagate",
// "path": "How to backpropagate"
// }
// ]
Link.detectLinkStyle()
Returns the link style ('markdown'
or 'wiki'
) of a provided string.
const markdownLink = new Link('[my markdown link](/path/to/file.md)');
const wikiLink = new Link('[[/path/to/file.md]]');
console.log(Link.detectLinkStyle(markdownLink));
// Output:
//
// 'markdown'
console.log(Link.detectLinkStyle(markdownLink));
// Output:
//
// 'wiki'
Link.prototype.composeHTML()
link.composeHTML([attributesStr])
Returns an HTML string based on the current Link
instance. The optional argument attributesStr
inserts custom attributes after the href
attribute.
const link = new Link('[my markdown link](/path/to/file.md)');
console.log(link.composeHTML());
// Output:
//
// '<a href="/path/to/file.md">my markdown link</a>'
const externalLinkAttributes = 'target="_blank" rel="noreferrer"';
console.log(link.composeHTML(externalLinkAttributes));
// Output:
//
// '<a href="/path/to/file.md" target="_blank" rel="noreferrer">my markdown link</a>'
Link.prototype.composeMarkdown()
link.composeMarkdown()
Returns a markdown link based on the current Link
instance.
const link = new Link('[my markdown link](/path/to/file.md)');
console.log(link.composeMarkdown());
// Output:
//
// '[my markdown link](/path/to/file.md)'
Link.prototype.composeWiki()
link.composeWiki()
Returns a wiki-style link based on the current Link
instance.
const link = new Link('[my markdown link](/path/to/file.md)');
console.log(link.composeWiki());
// Output:
//
// '[[/path/to/file.md]]'
Regex
This library exports an object containing useful regex patterns for extracting markdown and wiki-style links from string content. To use these patterns, import regex
from this package:
const { regex } = require("nonplain-md-link");
Related work
- Core nonplain library for JS: nonplain.js
- Generate backlinks for nonplain files: nonplain-md-backlinker.js
Contributing
These tools are in progress. If your use-case requires specific functionality from this library, please contact me and we'll see what we can do together. Thanks!