Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add support for line numbers #29

Closed
4 tasks done
L-Steinmacher opened this issue Oct 25, 2023 · 10 comments
Closed
4 tasks done

Add support for line numbers #29

L-Steinmacher opened this issue Oct 25, 2023 · 10 comments
Labels
💪 phase/solved Post is done

Comments

@L-Steinmacher
Copy link

Initial checklist

Problem

Currently there is no easy way to add line numbers for the parsed code as each individual element is a span. the usual way in css to add line nubers is to add a before on the span such as

pre span::before {
  counter-increment: line;
  content: counter(line);
  display: inline-block;
  width: 2em; /* Adjust as needed to suit your design */
  text-align: right;
  margin-right: 0.5em; /* Adjust as needed to suit your design */
  color: #999; /* Adjust the color as needed */
}

Solution

Add a wrapper span with special class to more easily add line numbers to code blocks.

Alternatives

If there is a current solution that I'm missing please inform me.

@github-actions github-actions bot added 👋 phase/new Post is being triaged automatically 🤞 phase/open Post is being triaged manually and removed 👋 phase/new Post is being triaged automatically labels Oct 25, 2023
@wooorm
Copy link
Member

wooorm commented Oct 25, 2023

Hey!

There’s an example with starry-night: https://github.com/wooorm/starry-night#example-adding-line-numbers.
That should likely work here, perhaps with minor adjustments.
I’m open to a similar example here. Not sure it should go in the project though. Perhaps.

@L-Steinmacher
Copy link
Author

Thank you for posting these examples! I don't know if only one example will do it for me right now. Here is my current setup with Unified

import remarkParse from 'remark-parse'
import remarkGfm from 'remark-gfm'
import { type Plugin, unified } from 'unified'
import remarkRehype from 'remark-rehype'
import rehypeStringify from 'rehype-stringify'
import rehypeHighlight from 'rehype-highlight'

export default async function markdownToHtml(markdown: string) {
  const result = await unified()
    .use(remarkParse as Plugin)
    .use(remarkGfm)
    .use(remarkRehype)
    .use(rehypeHighlight)
    .use(rehypeStringify)
    .process(markdown)
  return String(result)
}

Would you suggest using the stand alone function to call on the parsed html or integrate into the Unified call? Sorry for the newb questions.

@wooorm
Copy link
Member

wooorm commented Oct 26, 2023

Sorry for the newb questions.

No problem!

remarkParse as Plugin

That shouldn’t be needed?

Would you suggest using the stand alone function to call on the parsed html or integrate into the Unified call

starry-night is a little lower. It only does the AST. It isn’t on the level of plugins.
Here we are on that level. So it needs to be wrapped in a plugin.
ASTs are complex, but very powerful. So I’d recommend taking some time to play and learn with everything.

So, you’d need to write a rehype plugin that runs after this plugin. Then it would look for code blocks that were transformed, and add this gutter. The code for how to add the gutter should be very similar to that example in starry-night, but now operator on that node instead of an entire AST.

Feel free to ask more Qs!

@Caellian
Copy link

Caellian commented Jan 6, 2024

An approach I took from pure JS was just inserting a column flex with span elements for each line, make pre a flex as well, and number lines and content lines have same font properties so the text matches.

@talatkuyuk
Copy link
Contributor

talatkuyuk commented Jun 20, 2024

I've created a rehype plugin for line numbering and line highlighting for code blocks.

You can reach to rehype-highlight-code-lines on github and on npm.

Important

You need to use rehype-highlight before rehype-highlight-code-lines. They work together like a charm.

See some examples for rehype-highlight and rehype-highlight-code-lines work together.

A snapshot from above apps:
markdown code block input
markdown code block result

May I request that the author would add rehype-highlight-code-lines to the README.md home page and promote it?.

@wooorm
Copy link
Member

wooorm commented Jun 24, 2024

yes, sure, that’s good! Could go in “related” (https://github.com/rehypejs/rehype-highlight#related). And maybe somewhere else too?

@talatkuyuk
Copy link
Contributor

Thanks @wooorm . Line numbering and line highlighting is another most demanded feature align with code highlighting. For this reason, I want to get rehype-highlight-code-lines paired with rehype-highlight in the documentation. It could be more suitable to create a separate chapter after Example like below

Line Numbering and Line Highlighting

If it is suitable, I can create a PR, do I ?

@wooorm
Copy link
Member

wooorm commented Jun 24, 2024

yeah an example is also fine :)

I don’t think you need to delve too deep, in the example. Something short and basic seems like enough to me? People can always read more about line numbering in your readme?

@talatkuyuk
Copy link
Contributor

talatkuyuk commented Jul 2, 2024

I've created the PR #32

@wooorm wooorm closed this as completed in 67eeb3a Jul 12, 2024

This comment has been minimized.

@wooorm wooorm added the 💪 phase/solved Post is done label Jul 12, 2024
@github-actions github-actions bot removed the 🤞 phase/open Post is being triaged manually label Jul 12, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
💪 phase/solved Post is done
4 participants