Skip to content

Commit

Permalink
Mark remark-autolink-headings as legacy
Browse files Browse the repository at this point in the history
  • Loading branch information
wooorm committed Aug 16, 2021
1 parent 6860e28 commit 000ab47
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 244 deletions.
16 changes: 3 additions & 13 deletions package.json
Original file line number Diff line number Diff line change
@@ -1,19 +1,9 @@
{
"name": "remark-autolink-headings",
"version": "7.0.0",
"description": "remark plugin to automatically add links to headings",
"description": "Legacy remark plugin to automatically add links to headings — please use `rehype-autolink-headings` instead",
"license": "MIT",
"keywords": [
"unified",
"remark",
"remark-plugin",
"plugin",
"mdast",
"markdown",
"headings",
"link",
"automatic"
],
"keywords": [],
"repository": "remarkjs/remark-autolink-headings",
"bugs": "https://github.com/remarkjs/remark-autolink-headings/issues",
"funding": {
Expand Down Expand Up @@ -41,7 +31,7 @@
"unist-util-visit": "^4.0.0"
},
"devDependencies": {
"@types/extend": "^3.0.1",
"@types/extend": "^3.0.0",
"@types/tape": "^4.0.0",
"c8": "^7.0.0",
"hastscript": "^7.0.0",
Expand Down
240 changes: 9 additions & 231 deletions readme.md
Original file line number Diff line number Diff line change
@@ -1,246 +1,24 @@
# remark-autolink-headings

[![Build][build-badge]][build]
[![Coverage][coverage-badge]][coverage]
[![Downloads][downloads-badge]][downloads]
[![Size][size-badge]][size]
[![Sponsors][sponsors-badge]][collective]
[![Backers][backers-badge]][collective]
[![Chat][chat-badge]][chat]
**Stability: Legacy**.
This package is no longer recommended for use.
It’s still covered by semantic-versioning guarantees and not yet deprecated,
but use of this package should be avoided.
Please use `remark-rehype` to move from remark (markdown) to rehype (HTML)
and then replace `remark-autolink-headings` with
[`rehype-autolink-headings`][rehype-autolink-headings].

[**remark**][remark] plugin to automatically add links to headings.

> This package integrates with [`remark-html`][remark-html] (or alternatives).
> It is better to work with [**rehype**][rehype], which is specifically made
> for HTML, and to use [`rehype-autolink-headings`][rehype-autolink-headings]
> instead of this package.
<!---->

> This package works with headings that have IDs.
> One way to add IDs to headings is by using [`remark-slug`][remark-slug] before
> this plugin.
## Note!

This plugin is ready for the new parser in remark
([`remarkjs/remark#536`](https://github.com/remarkjs/remark/pull/536)).
No change is needed: it works exactly the same now as it did before!

## Install

This package is [ESM only](https://gist.github.com/sindresorhus/a39789f98801d908bbc7ff3ecc99d99c):
Node 12+ is needed to use it and it must be `import`ed instead of `require`d.

[npm][]:

```sh
npm install remark-autolink-headings
```

## Use

Say we have the following markdown file, `example.md`:

```markdown
# Lorem ipsum 😪
## dolor—sit—amet
### consectetur &amp; adipisicing
#### elit
##### elit
```

And our module, `example.js`, looks as follows:

```js
import fs from 'node:fs'
import {unified} from 'unified'
import remarkParse from 'remark-parse'
import remarkSlug from 'remark-slug'
import remarkAutolinkHeadings from 'remark-autolink-headings'
import remarkHtml from 'remark-html'

const doc = unified()
.use(remarkParse)
.use(remarkSlug)
// Note that this module must be included after `remark-slug`.
.use(remarkAutolinkHeadings)
.use(remarkHtml)
.processSync(fs.readFileSync('example.md'))
.toString()

console.log(doc)
```

Now, running `node example` yields:

```html
<h1 id="lorem-ipsum-"><a href="#lorem-ipsum-" aria-hidden="true" tabindex="-1"><span class="icon icon-link"></span></a>Lorem ipsum 😪</h1>
<h2 id="dolorsitamet"><a href="#dolorsitamet" aria-hidden="true" tabindex="-1"><span class="icon icon-link"></span></a>dolor—sit—amet</h2>
<h3 id="consectetur--adipisicing"><a href="#consectetur--adipisicing" aria-hidden="true" tabindex="-1"><span class="icon icon-link"></span></a>consectetur &#x26; adipisicing</h3>
<h4 id="elit"><a href="#elit" aria-hidden="true" tabindex="-1"><span class="icon icon-link"></span></a>elit</h4>
<h5 id="elit-1"><a href="#elit-1" aria-hidden="true" tabindex="-1"><span class="icon icon-link"></span></a>elit</h5>
```

## API

This package exports no identifiers.
The default export is `remarkAutolinkHeadings`.

### `unified().use(remarkAutolinkHeadings[, options])`

Automatically add links to headings.

##### `options`

###### `options.behavior`

How to create links (`string`, default: `'prepend'`).

* `'prepend'` — inject link before the heading text
* `'append'` — inject link after the heading text
* `'wrap'` — wrap the whole heading text with the link
* `'before'` — insert link before the heading
* `'after'` — insert link after the heading

Supplying `wrap` will ignore any value defined by the `content` option.
Supplying `prepend`, `append`, or `wrap` will ignore the `group` option.

###### `options.linkProperties`

Extra properties to set on the link (`Object?`).
Defaults to `{ariaHidden: 'true', tabIndex: -1}` when in `'prepend'` or `'append'`
mode.

###### `options.content`

[**hast**][hast] nodes to insert in the link (`Function|Node|Children`).
By default, the following is used:

```js
{
type: 'element',
tagName: 'span',
properties: {className: ['icon', 'icon-link']}
}
```

If `behavior` is `wrap`, then `content` is ignored.

If `content` is a function, it’s called with the current heading (`Node`) and
should return one or more nodes:

```js
const toString = require('mdast-util-to-string')
const h = require('hastscript')

//

function content(node) {
return [
h('span.visually-hidden', 'Read the “', toString(node), '” section'),
h('span.icon.icon-link', {ariaHidden: 'true'})
]
}
```

###### `options.group`

[**hast**][hast] node to wrap the heading and link with (`Function|Node`), if
`behavior` is `before` or `after`.
There is no default.

If `behavior` is `prepend`, `append`, or `wrap`, then `group` is ignored.

If `group` is a function, it’s called with the current heading (`Node`) and
should return a hast node.

```js
const h = require('hastscript')

//

function group(node) {
return h('div.heading-' + node.depth + '-group')
}
```

## Security

Use of `remark-autolink-headings` can open you up to a
[cross-site scripting (XSS)][xss] attack if you pass user provided content in
`linkProperties` or `content`.

Always be wary of user input and use [`rehype-sanitize`][sanitize].

## Contribute

See [`contributing.md`][contributing] in [`remarkjs/.github`][health] for ways
to get started.
See [`support.md`][support] for ways to get help.

This project has a [code of conduct][coc].
By interacting with this repository, organization, or community you agree to
abide by its terms.
Legacy [documentation for this package](https://github.com/remarkjs/remark-autolink-headings/tree/91254a60bfe03163cb49f08ec20ca5d34f677b7c)
is still available in Git.

## License

[MIT][license] © [Ben Briggs][author]

<!-- Definitions -->

[build-badge]: https://github.com/remarkjs/remark-autolink-headings/workflows/main/badge.svg

[build]: https://github.com/remarkjs/remark-autolink-headings/actions

[coverage-badge]: https://img.shields.io/codecov/c/github/remarkjs/remark-autolink-headings.svg

[coverage]: https://codecov.io/github/remarkjs/remark-autolink-headings

[downloads-badge]: https://img.shields.io/npm/dm/remark-autolink-headings.svg

[downloads]: https://www.npmjs.com/package/remark-autolink-headings

[size-badge]: https://img.shields.io/bundlephobia/minzip/remark-autolink-headings.svg

[size]: https://bundlephobia.com/result?p=remark-autolink-headings

[sponsors-badge]: https://opencollective.com/unified/sponsors/badge.svg

[backers-badge]: https://opencollective.com/unified/backers/badge.svg

[collective]: https://opencollective.com/unified

[chat-badge]: https://img.shields.io/badge/chat-discussions-success.svg

[chat]: https://github.com/remarkjs/remark/discussions

[npm]: https://docs.npmjs.com/cli/install

[health]: https://github.com/remarkjs/.github

[contributing]: https://github.com/remarkjs/.github/blob/HEAD/contributing.md

[support]: https://github.com/remarkjs/.github/blob/HEAD/support.md

[coc]: https://github.com/remarkjs/.github/blob/HEAD/code-of-conduct.md

[license]: license

[author]: http://beneb.info

[remark]: https://github.com/remarkjs/remark

[remark-slug]: https://github.com/remarkjs/remark-slug

[remark-html]: https://github.com/remarkjs/remark-html

[rehype]: https://github.com/rehypejs/rehype

[rehype-autolink-headings]: https://github.com/rehypejs/rehype-autolink-headings

[hast]: https://github.com/syntax-tree/hast

[xss]: https://en.wikipedia.org/wiki/Cross-site_scripting

[sanitize]: https://github.com/rehypejs/rehype-sanitize

0 comments on commit 000ab47

Please sign in to comment.