2019-11-17 12:18:01 -08:00
|
|
|
/*
|
|
|
|
Package html implements HTML renderer of parsed markdown document.
|
|
|
|
|
|
|
|
Configuring and customizing a renderer
|
|
|
|
|
|
|
|
A renderer can be configured with multiple options:
|
|
|
|
|
|
|
|
import "github.com/gomarkdown/markdown/html"
|
|
|
|
|
|
|
|
flags := html.CommonFlags | html.CompletePage | html.HrefTargetBlank
|
2020-02-02 09:35:43 -08:00
|
|
|
opts := html.RendererOptions{
|
2021-05-05 13:03:28 -07:00
|
|
|
Title: "A custom title",
|
2019-11-17 12:18:01 -08:00
|
|
|
Flags: flags,
|
|
|
|
}
|
|
|
|
renderer := html.NewRenderer(opts)
|
|
|
|
|
|
|
|
You can also re-use most of the logic and customize rendering of selected nodes
|
|
|
|
by providing node render hook.
|
|
|
|
This is most useful for rendering nodes that allow for design choices, like
|
|
|
|
links or code blocks.
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/gomarkdown/markdown/html"
|
|
|
|
"github.com/gomarkdown/markdown/ast"
|
|
|
|
)
|
|
|
|
|
|
|
|
// a very dummy render hook that will output "code_replacements" instead of
|
|
|
|
// <code>${content}</code> emitted by html.Renderer
|
2022-05-01 15:10:54 -07:00
|
|
|
func renderHookCodeBlock(w io.Writer, node ast.Node, entering bool) (ast.WalkStatus, bool) {
|
|
|
|
_, ok := node.(*ast.CodeBlock)
|
2019-11-17 12:18:01 -08:00
|
|
|
if !ok {
|
|
|
|
return ast.GoToNext, false
|
|
|
|
}
|
|
|
|
io.WriteString(w, "code_replacement")
|
|
|
|
return ast.GoToNext, true
|
|
|
|
}
|
|
|
|
|
|
|
|
opts := html.RendererOptions{
|
|
|
|
RenderNodeHook: renderHookCodeBlock,
|
|
|
|
}
|
|
|
|
renderer := html.NewRenderer(opts)
|
|
|
|
*/
|
|
|
|
package html
|