mirror of
				https://github.com/kovetskiy/mark.git
				synced 2025-10-25 07:57:35 +08:00 
			
		
		
		
	feat: add Support for converting Material for MkDocs Admonitions to Confluence Info Panels
chore: add test files fix: add tests for stripnewline and droph1 chore: rename Admontion to MkDocsAdmonition, remove annoying comments fix: import parser instead of copying the file chore: rename mkDocs renderer function fix: fix bug and pipeline feat: add Support for converting Material for MkDocs Admonitions to Confluence Info Panels fix: add tests for stripnewline and droph1 chore: rename Admontion to MkDocsAdmonition, remove annoying comments fix: import parser instead of copying the file chore: rename mkDocs renderer function fix: fix bug and pipeline chore: remove test for droph1 and stripNewLines fix: add admonitions to StripNewLines and dropH1 tests feat: add Support for converting Material for MkDocs Admonitions to Confluence Info Panels fix: add tests for stripnewline and droph1 chore: rename Admontion to MkDocsAdmonition, remove annoying comments fix: import parser instead of copying the file chore: rename mkDocs renderer function fix: fix bug and pipeline feat: add Support for converting Material for MkDocs Admonitions to Confluence Info Panels chore: rename Admontion to MkDocsAdmonition, remove annoying comments fix: import parser instead of copying the file chore: rename mkDocs renderer function fix: fix bug and pipeline chore: remove test for droph1 and stripNewLines fix: add admonitions to StripNewLines and dropH1 tests feat: add mkdocsadmonition as opt-in renderer and parser fix: fix unit tests
This commit is contained in:
		
							parent
							
								
									242cebb5ee
								
							
						
					
					
						commit
						32490b2c90
					
				
							
								
								
									
										1
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								go.mod
									
									
									
									
									
								
							| @ -14,6 +14,7 @@ require ( | |||||||
| 	github.com/reconquest/karma-go v1.5.0 | 	github.com/reconquest/karma-go v1.5.0 | ||||||
| 	github.com/reconquest/pkg v1.3.1-0.20240901105413-68c2adbf2b64 | 	github.com/reconquest/pkg v1.3.1-0.20240901105413-68c2adbf2b64 | ||||||
| 	github.com/reconquest/regexputil-go v0.0.0-20160905154124-38573e70c1f4 | 	github.com/reconquest/regexputil-go v0.0.0-20160905154124-38573e70c1f4 | ||||||
|  | 	github.com/stefanfritsch/goldmark-admonitions v1.1.1 | ||||||
| 	github.com/stretchr/testify v1.10.0 | 	github.com/stretchr/testify v1.10.0 | ||||||
| 	github.com/urfave/cli-altsrc/v3 v3.0.1 | 	github.com/urfave/cli-altsrc/v3 v3.0.1 | ||||||
| 	github.com/urfave/cli/v3 v3.3.8 | 	github.com/urfave/cli/v3 v3.3.8 | ||||||
|  | |||||||
							
								
								
									
										4
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								go.sum
									
									
									
									
									
								
							| @ -90,6 +90,10 @@ github.com/rivo/uniseg v0.4.7 h1:WUdvkW8uEhrYfLC4ZzdpI2ztxP1I582+49Oc5Mq64VQ= | |||||||
| github.com/rivo/uniseg v0.4.7/go.mod h1:FN3SvrM+Zdj16jyLfmOkMNblXMcoc8DfTHruCPUcx88= | github.com/rivo/uniseg v0.4.7/go.mod h1:FN3SvrM+Zdj16jyLfmOkMNblXMcoc8DfTHruCPUcx88= | ||||||
| github.com/rogpeppe/go-internal v1.9.0 h1:73kH8U+JUqXU8lRuOHeVHaa/SZPifC7BkcraZVejAe8= | github.com/rogpeppe/go-internal v1.9.0 h1:73kH8U+JUqXU8lRuOHeVHaa/SZPifC7BkcraZVejAe8= | ||||||
| github.com/rogpeppe/go-internal v1.9.0/go.mod h1:WtVeX8xhTBvf0smdhujwtBcq4Qrzq/fJaraNFVN+nFs= | github.com/rogpeppe/go-internal v1.9.0/go.mod h1:WtVeX8xhTBvf0smdhujwtBcq4Qrzq/fJaraNFVN+nFs= | ||||||
|  | github.com/russross/blackfriday/v2 v2.1.0 h1:JIOH55/0cWyOuilr9/qlrm0BSXldqnqwMsf35Ld67mk= | ||||||
|  | github.com/russross/blackfriday/v2 v2.1.0/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM= | ||||||
|  | github.com/stefanfritsch/goldmark-admonitions v1.1.1 h1:SncsICdQrIYYaq02Ta+zyc9gNmMfYqQH2qwLSCJYxA4= | ||||||
|  | github.com/stefanfritsch/goldmark-admonitions v1.1.1/go.mod h1:cOZK5O0gE6eWfpxTdjGUmeONW2IL9j3Zujv3KlZWlLo= | ||||||
| github.com/stretchr/testify v1.10.0 h1:Xv5erBjTwe/5IxqUQTdXv5kgmIvbHo3QQyRwhJsOfJA= | github.com/stretchr/testify v1.10.0 h1:Xv5erBjTwe/5IxqUQTdXv5kgmIvbHo3QQyRwhJsOfJA= | ||||||
| github.com/stretchr/testify v1.10.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY= | github.com/stretchr/testify v1.10.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY= | ||||||
| github.com/urfave/cli-altsrc/v3 v3.0.1 h1:v+gHk59syLk8ao9rYybZs43+D5ut/gzj0omqQ1XYl8k= | github.com/urfave/cli-altsrc/v3 v3.0.1 h1:v+gHk59syLk8ao9rYybZs43+D5ut/gzj0omqQ1XYl8k= | ||||||
|  | |||||||
| @ -2,6 +2,7 @@ package mark | |||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
| 	"bytes" | 	"bytes" | ||||||
|  | 	"slices" | ||||||
| 
 | 
 | ||||||
| 	"github.com/kovetskiy/mark/attachment" | 	"github.com/kovetskiy/mark/attachment" | ||||||
| 	cparser "github.com/kovetskiy/mark/parser" | 	cparser "github.com/kovetskiy/mark/parser" | ||||||
| @ -9,6 +10,7 @@ import ( | |||||||
| 	"github.com/kovetskiy/mark/stdlib" | 	"github.com/kovetskiy/mark/stdlib" | ||||||
| 	"github.com/kovetskiy/mark/types" | 	"github.com/kovetskiy/mark/types" | ||||||
| 	"github.com/reconquest/pkg/log" | 	"github.com/reconquest/pkg/log" | ||||||
|  | 	mkDocsParser "github.com/stefanfritsch/goldmark-admonitions" | ||||||
| 	"github.com/yuin/goldmark" | 	"github.com/yuin/goldmark" | ||||||
| 
 | 
 | ||||||
| 	"github.com/yuin/goldmark/extension" | 	"github.com/yuin/goldmark/extension" | ||||||
| @ -56,6 +58,18 @@ func (c *ConfluenceExtension) Extend(m goldmark.Markdown) { | |||||||
| 		util.Prioritized(crenderer.NewConfluenceLinkRenderer(), 100), | 		util.Prioritized(crenderer.NewConfluenceLinkRenderer(), 100), | ||||||
| 	)) | 	)) | ||||||
| 
 | 
 | ||||||
|  | 	if slices.Contains(c.MarkConfig.Features, "mkdocsadmonitions") { | ||||||
|  | 		m.Parser().AddOptions( | ||||||
|  | 			parser.WithBlockParsers( | ||||||
|  | 				util.Prioritized(mkDocsParser.NewAdmonitionParser(), 100), | ||||||
|  | 			), | ||||||
|  | 		) | ||||||
|  | 
 | ||||||
|  | 		m.Renderer().AddOptions(renderer.WithNodeRenderers( | ||||||
|  | 			util.Prioritized(crenderer.NewConfluenceMkDocsAdmonitionRenderer(), 100), | ||||||
|  | 		)) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	m.Parser().AddOptions(parser.WithInlineParsers( | 	m.Parser().AddOptions(parser.WithInlineParsers( | ||||||
| 		// Must be registered with a higher priority than goldmark's linkParser to make sure goldmark doesn't parse | 		// Must be registered with a higher priority than goldmark's linkParser to make sure goldmark doesn't parse | ||||||
| 		// the <ac:*/> tags. | 		// the <ac:*/> tags. | ||||||
|  | |||||||
| @ -63,7 +63,7 @@ func TestCompileMarkdown(t *testing.T) { | |||||||
| 			D2Scale:         1.0, | 			D2Scale:         1.0, | ||||||
| 			DropFirstH1:     false, | 			DropFirstH1:     false, | ||||||
| 			StripNewlines:   false, | 			StripNewlines:   false, | ||||||
| 			Features:        []string{}, | 			Features:        []string{"mkdocsadmonitions"}, | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		actual, _ := mark.CompileMarkdown(markdown, lib, filename, cfg) | 		actual, _ := mark.CompileMarkdown(markdown, lib, filename, cfg) | ||||||
| @ -93,7 +93,7 @@ func TestCompileMarkdownDropH1(t *testing.T) { | |||||||
| 		} | 		} | ||||||
| 		var variant string | 		var variant string | ||||||
| 		switch filename { | 		switch filename { | ||||||
| 		case "testdata/quotes.md", "testdata/header.md": | 		case "testdata/quotes.md", "testdata/header.md", "testdata/admonitions.md": | ||||||
| 			variant = "-droph1" | 			variant = "-droph1" | ||||||
| 		default: | 		default: | ||||||
| 			variant = "" | 			variant = "" | ||||||
| @ -103,10 +103,10 @@ func TestCompileMarkdownDropH1(t *testing.T) { | |||||||
| 		cfg := types.MarkConfig{ | 		cfg := types.MarkConfig{ | ||||||
| 			MermaidProvider: "", | 			MermaidProvider: "", | ||||||
| 			MermaidScale:    1.0, | 			MermaidScale:    1.0, | ||||||
| 			D2Scale:	 1.0, | 			D2Scale:         1.0, | ||||||
| 			DropFirstH1:     true, | 			DropFirstH1:     true, | ||||||
| 			StripNewlines:   false, | 			StripNewlines:   false, | ||||||
| 			Features:        []string{}, | 			Features:        []string{"mkdocsadmonitions"}, | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		actual, _ := mark.CompileMarkdown(markdown, lib, filename, cfg) | 		actual, _ := mark.CompileMarkdown(markdown, lib, filename, cfg) | ||||||
| @ -137,7 +137,7 @@ func TestCompileMarkdownStripNewlines(t *testing.T) { | |||||||
| 		} | 		} | ||||||
| 		var variant string | 		var variant string | ||||||
| 		switch filename { | 		switch filename { | ||||||
| 		case "testdata/quotes.md", "testdata/codes.md", "testdata/newlines.md", "testdata/macro-include.md": | 		case "testdata/quotes.md", "testdata/codes.md", "testdata/newlines.md", "testdata/macro-include.md", "testdata/admonitions.md": | ||||||
| 			variant = "-stripnewlines" | 			variant = "-stripnewlines" | ||||||
| 		default: | 		default: | ||||||
| 			variant = "" | 			variant = "" | ||||||
| @ -151,7 +151,7 @@ func TestCompileMarkdownStripNewlines(t *testing.T) { | |||||||
| 			D2Scale:         1.0, | 			D2Scale:         1.0, | ||||||
| 			DropFirstH1:     false, | 			DropFirstH1:     false, | ||||||
| 			StripNewlines:   true, | 			StripNewlines:   true, | ||||||
| 			Features:        []string{}, | 			Features:        []string{"mkdocsadmonitions"}, | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		actual, _ := mark.CompileMarkdown(markdown, lib, filename, cfg) | 		actual, _ := mark.CompileMarkdown(markdown, lib, filename, cfg) | ||||||
|  | |||||||
							
								
								
									
										150
									
								
								renderer/mkDocsAdmonition.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										150
									
								
								renderer/mkDocsAdmonition.go
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,150 @@ | |||||||
|  | package renderer | ||||||
|  | 
 | ||||||
|  | import ( | ||||||
|  | 	"fmt" | ||||||
|  | 
 | ||||||
|  | 	parser "github.com/stefanfritsch/goldmark-admonitions" | ||||||
|  | 	"github.com/yuin/goldmark/ast" | ||||||
|  | 	"github.com/yuin/goldmark/renderer" | ||||||
|  | 	"github.com/yuin/goldmark/renderer/html" | ||||||
|  | 	"github.com/yuin/goldmark/util" | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | // HeadingAttributeFilter defines attribute names which heading elements can have | ||||||
|  | var MkDocsAdmonitionAttributeFilter = html.GlobalAttributeFilter | ||||||
|  | 
 | ||||||
|  | // A Renderer struct is an implementation of renderer.NodeRenderer that renders | ||||||
|  | // nodes as (X)HTML. | ||||||
|  | type ConfluenceMkDocsAdmonitionRenderer struct { | ||||||
|  | 	html.Config | ||||||
|  | 	LevelMap MkDocsAdmonitionLevelMap | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // NewConfluenceRenderer creates a new instance of the ConfluenceRenderer | ||||||
|  | func NewConfluenceMkDocsAdmonitionRenderer(opts ...html.Option) renderer.NodeRenderer { | ||||||
|  | 	return &ConfluenceMkDocsAdmonitionRenderer{ | ||||||
|  | 		Config:   html.NewConfig(), | ||||||
|  | 		LevelMap: nil, | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // RegisterFuncs implements NodeRenderer.RegisterFuncs. | ||||||
|  | func (r *ConfluenceMkDocsAdmonitionRenderer) RegisterFuncs(reg renderer.NodeRendererFuncRegisterer) { | ||||||
|  | 	reg.Register(parser.KindAdmonition, r.renderMkDocsAdmonition) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // Define MkDocsAdmonitionType enum | ||||||
|  | type MkDocsAdmonitionType int | ||||||
|  | 
 | ||||||
|  | const ( | ||||||
|  | 	AInfo MkDocsAdmonitionType = iota | ||||||
|  | 	ANote | ||||||
|  | 	AWarn | ||||||
|  | 	ATip | ||||||
|  | 	ANone | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | func (t MkDocsAdmonitionType) String() string { | ||||||
|  | 	return []string{"info", "note", "warning", "tip", "none"}[t] | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | type MkDocsAdmonitionLevelMap map[ast.Node]int | ||||||
|  | 
 | ||||||
|  | func (m MkDocsAdmonitionLevelMap) Level(node ast.Node) int { | ||||||
|  | 	return m[node] | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func ParseMkDocsAdmonitionType(node ast.Node) MkDocsAdmonitionType { | ||||||
|  | 	n, ok := node.(*parser.Admonition) | ||||||
|  | 	if !ok { | ||||||
|  | 		return ANone | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	switch string(n.AdmonitionClass) { | ||||||
|  | 	case "info": | ||||||
|  | 		return AInfo | ||||||
|  | 	case "note": | ||||||
|  | 		return ANote | ||||||
|  | 	case "warning": | ||||||
|  | 		return AWarn | ||||||
|  | 	case "tip": | ||||||
|  | 		return ATip | ||||||
|  | 	default: | ||||||
|  | 		return ANone | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // GenerateMkDocsAdmonitionLevel walks a given node and returns a map of blockquote levels | ||||||
|  | func GenerateMkDocsAdmonitionLevel(someNode ast.Node) MkDocsAdmonitionLevelMap { | ||||||
|  | 
 | ||||||
|  | 	// We define state variable that tracks BlockQuote level while we walk the tree | ||||||
|  | 	admonitionLevel := 0 | ||||||
|  | 	AdmonitionLevelMap := make(map[ast.Node]int) | ||||||
|  | 
 | ||||||
|  | 	rootNode := someNode | ||||||
|  | 	for rootNode.Parent() != nil { | ||||||
|  | 		rootNode = rootNode.Parent() | ||||||
|  | 	} | ||||||
|  | 	_ = ast.Walk(rootNode, func(node ast.Node, entering bool) (ast.WalkStatus, error) { | ||||||
|  | 		if node.Kind() == ast.KindBlockquote && entering { | ||||||
|  | 			AdmonitionLevelMap[node] = admonitionLevel | ||||||
|  | 			admonitionLevel += 1 | ||||||
|  | 		} | ||||||
|  | 		if node.Kind() == ast.KindBlockquote && !entering { | ||||||
|  | 			admonitionLevel -= 1 | ||||||
|  | 		} | ||||||
|  | 		return ast.WalkContinue, nil | ||||||
|  | 	}) | ||||||
|  | 	return AdmonitionLevelMap | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // renderBlockQuote will render a BlockQuote | ||||||
|  | func (r *ConfluenceMkDocsAdmonitionRenderer) renderMkDocsAdmonition(writer util.BufWriter, source []byte, node ast.Node, entering bool) (ast.WalkStatus, error) { | ||||||
|  | 	//	Initialize BlockQuote level map | ||||||
|  | 	n := node.(*parser.Admonition) | ||||||
|  | 	if r.LevelMap == nil { | ||||||
|  | 		r.LevelMap = GenerateMkDocsAdmonitionLevel(node) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	admonitionType := ParseMkDocsAdmonitionType(node) | ||||||
|  | 	admonitionLevel := r.LevelMap.Level(node) | ||||||
|  | 
 | ||||||
|  | 	if admonitionLevel == 0 && entering && admonitionType != ANone { | ||||||
|  | 		prefix := fmt.Sprintf("<ac:structured-macro ac:name=\"%s\"><ac:parameter ac:name=\"icon\">true</ac:parameter><ac:rich-text-body>\n", admonitionType) | ||||||
|  | 		if _, err := writer.Write([]byte(prefix)); err != nil { | ||||||
|  | 			return ast.WalkStop, err | ||||||
|  | 		} | ||||||
|  | 		if string(n.Title) != "" { | ||||||
|  | 			titleHTML := fmt.Sprintf("<p><strong>%s</strong></p>\n", string(n.Title)) | ||||||
|  | 			if _, err := writer.Write([]byte(titleHTML)); err != nil { | ||||||
|  | 				return ast.WalkStop, err | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		return ast.WalkContinue, nil | ||||||
|  | 	} | ||||||
|  | 	if admonitionLevel == 0 && !entering && admonitionType != ANone { | ||||||
|  | 		suffix := "</ac:rich-text-body></ac:structured-macro>\n" | ||||||
|  | 		if _, err := writer.Write([]byte(suffix)); err != nil { | ||||||
|  | 			return ast.WalkStop, err | ||||||
|  | 		} | ||||||
|  | 		return ast.WalkContinue, nil | ||||||
|  | 	} | ||||||
|  | 	return r.renderMkDocsAdmon(writer, source, node, entering) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (r *ConfluenceMkDocsAdmonitionRenderer) renderMkDocsAdmon(w util.BufWriter, source []byte, node ast.Node, entering bool) (ast.WalkStatus, error) { | ||||||
|  | 	n := node.(*parser.Admonition) | ||||||
|  | 	if entering { | ||||||
|  | 		if n.Attributes() != nil { | ||||||
|  | 			_, _ = w.WriteString("<blockquote") | ||||||
|  | 			html.RenderAttributes(w, n, MkDocsAdmonitionAttributeFilter) | ||||||
|  | 			_ = w.WriteByte('>') | ||||||
|  | 		} else { | ||||||
|  | 			_, _ = w.WriteString("<blockquote>\n") | ||||||
|  | 		} | ||||||
|  | 	} else { | ||||||
|  | 		_, _ = w.WriteString("</blockquote>\n") | ||||||
|  | 	} | ||||||
|  | 	return ast.WalkContinue, nil | ||||||
|  | } | ||||||
							
								
								
									
										83
									
								
								testdata/admonitions-droph1.html
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										83
									
								
								testdata/admonitions-droph1.html
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,83 @@ | |||||||
|  | <h2 id="First-Heading">First Heading</h2> | ||||||
|  | <ac:structured-macro ac:name="note"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p><strong>"NOTES:"</strong></p> | ||||||
|  | <ol> | ||||||
|  | <li>Note number one</li> | ||||||
|  | <li>Note number two</li> | ||||||
|  | </ol> | ||||||
|  | <ac:structured-macro ac:name="note"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p>a<br /> | ||||||
|  | b</p> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <p><strong>Warn (Should not be picked as blockquote type)</strong></p> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <h2 id="Second-Heading">Second Heading</h2> | ||||||
|  | <ac:structured-macro ac:name="warning"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p><strong>"Warn"</strong></p> | ||||||
|  | <ul> | ||||||
|  | <li>Warn bullet 1</li> | ||||||
|  | <li>Warn bullet 2</li> | ||||||
|  | </ul> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <ul> | ||||||
|  | <li>Regular list | ||||||
|  | that runs long</li> | ||||||
|  | </ul> | ||||||
|  | <h2 id="Third-Heading">Third Heading</h2> | ||||||
|  | <ac:structured-macro ac:name="info"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p>Test</p> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <h2 id="Fourth-Heading---Warn-should-not-get-picked-as-block-quote">Fourth Heading - Warn should not get picked as block quote</h2> | ||||||
|  | <ac:structured-macro ac:name="tip"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p><strong>"TIP:"</strong></p> | ||||||
|  | <ol> | ||||||
|  | <li>Note number one</li> | ||||||
|  | <li>Note number two</li> | ||||||
|  | </ol> | ||||||
|  | <ac:structured-macro ac:name="tip"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p>a<br /> | ||||||
|  | b</p> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <p><strong>Warn (Should not be picked as blockquote type)</strong></p> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <h2 id="Simple-Blockquote">Simple Blockquote</h2> | ||||||
|  | <blockquote> | ||||||
|  | <p>This paragraph is a simple blockquote</p> | ||||||
|  | </blockquote> | ||||||
|  | <h2 id="GH-Alerts-Heading">GH Alerts Heading</h2> | ||||||
|  | <h3 id="Note-Type-Alert-Heading">Note Type Alert Heading</h3> | ||||||
|  | <ac:structured-macro ac:name="note"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <ul> | ||||||
|  | <li>Note bullet 1</li> | ||||||
|  | <li>Note bullet 2</li> | ||||||
|  | </ul> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <h3 id="Tip-Type-Alert-Heading">Tip Type Alert Heading</h3> | ||||||
|  | <ac:structured-macro ac:name="tip"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <ul> | ||||||
|  | <li>Tip bullet 1</li> | ||||||
|  | <li>Tip bullet 2</li> | ||||||
|  | </ul> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <h3 id="Warning-Type-Alert-Heading">Warning Type Alert Heading</h3> | ||||||
|  | <ac:structured-macro ac:name="warning"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <ul> | ||||||
|  | <li>Warning bullet 1</li> | ||||||
|  | <li>Warning bullet 2</li> | ||||||
|  | </ul> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <h3 id="Important/Caution-Type-Alert-Heading">Important/Caution Type Alert Heading</h3> | ||||||
|  | <ac:structured-macro ac:name="info"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p><strong>"[!IMPORTANT]"</strong></p> | ||||||
|  | <ul> | ||||||
|  | <li>Important bullet 1</li> | ||||||
|  | <li>Important bullet 2</li> | ||||||
|  | </ul> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <ac:structured-macro ac:name="warning"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p><strong>"[!CAUTION]"</strong></p> | ||||||
|  | <ul> | ||||||
|  | <li>Important bullet 1</li> | ||||||
|  | <li>Important bullet 2</li> | ||||||
|  | </ul> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
							
								
								
									
										83
									
								
								testdata/admonitions-stripnewlines.html
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										83
									
								
								testdata/admonitions-stripnewlines.html
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,83 @@ | |||||||
|  | <h1 id="Main-Heading">Main Heading</h1> | ||||||
|  | <h2 id="First-Heading">First Heading</h2> | ||||||
|  | <ac:structured-macro ac:name="note"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p><strong>"NOTES:"</strong></p> | ||||||
|  | <ol> | ||||||
|  | <li>Note number one</li> | ||||||
|  | <li>Note number two</li> | ||||||
|  | </ol> | ||||||
|  | <ac:structured-macro ac:name="note"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p>a<br /> | ||||||
|  | b</p> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <p><strong>Warn (Should not be picked as blockquote type)</strong></p> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <h2 id="Second-Heading">Second Heading</h2> | ||||||
|  | <ac:structured-macro ac:name="warning"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p><strong>"Warn"</strong></p> | ||||||
|  | <ul> | ||||||
|  | <li>Warn bullet 1</li> | ||||||
|  | <li>Warn bullet 2</li> | ||||||
|  | </ul> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <ul> | ||||||
|  | <li>Regular list that runs long</li> | ||||||
|  | </ul> | ||||||
|  | <h2 id="Third-Heading">Third Heading</h2> | ||||||
|  | <ac:structured-macro ac:name="info"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p>Test</p> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <h2 id="Fourth-Heading---Warn-should-not-get-picked-as-block-quote">Fourth Heading - Warn should not get picked as block quote</h2> | ||||||
|  | <ac:structured-macro ac:name="tip"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p><strong>"TIP:"</strong></p> | ||||||
|  | <ol> | ||||||
|  | <li>Note number one</li> | ||||||
|  | <li>Note number two</li> | ||||||
|  | </ol> | ||||||
|  | <ac:structured-macro ac:name="tip"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p>a<br /> | ||||||
|  | b</p> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <p><strong>Warn (Should not be picked as blockquote type)</strong></p> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <h2 id="Simple-Blockquote">Simple Blockquote</h2> | ||||||
|  | <blockquote> | ||||||
|  | <p>This paragraph is a simple blockquote</p> | ||||||
|  | </blockquote> | ||||||
|  | <h2 id="GH-Alerts-Heading">GH Alerts Heading</h2> | ||||||
|  | <h3 id="Note-Type-Alert-Heading">Note Type Alert Heading</h3> | ||||||
|  | <ac:structured-macro ac:name="note"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <ul> | ||||||
|  | <li>Note bullet 1</li> | ||||||
|  | <li>Note bullet 2</li> | ||||||
|  | </ul> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <h3 id="Tip-Type-Alert-Heading">Tip Type Alert Heading</h3> | ||||||
|  | <ac:structured-macro ac:name="tip"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <ul> | ||||||
|  | <li>Tip bullet 1</li> | ||||||
|  | <li>Tip bullet 2</li> | ||||||
|  | </ul> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <h3 id="Warning-Type-Alert-Heading">Warning Type Alert Heading</h3> | ||||||
|  | <ac:structured-macro ac:name="warning"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <ul> | ||||||
|  | <li>Warning bullet 1</li> | ||||||
|  | <li>Warning bullet 2</li> | ||||||
|  | </ul> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <h3 id="Important/Caution-Type-Alert-Heading">Important/Caution Type Alert Heading</h3> | ||||||
|  | <ac:structured-macro ac:name="info"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p><strong>"[!IMPORTANT]"</strong></p> | ||||||
|  | <ul> | ||||||
|  | <li>Important bullet 1</li> | ||||||
|  | <li>Important bullet 2</li> | ||||||
|  | </ul> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <ac:structured-macro ac:name="warning"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p><strong>"[!CAUTION]"</strong></p> | ||||||
|  | <ul> | ||||||
|  | <li>Important bullet 1</li> | ||||||
|  | <li>Important bullet 2</li> | ||||||
|  | </ul> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
							
								
								
									
										84
									
								
								testdata/admonitions.html
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										84
									
								
								testdata/admonitions.html
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,84 @@ | |||||||
|  | <h1 id="Main-Heading">Main Heading</h1> | ||||||
|  | <h2 id="First-Heading">First Heading</h2> | ||||||
|  | <ac:structured-macro ac:name="note"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p><strong>"NOTES:"</strong></p> | ||||||
|  | <ol> | ||||||
|  | <li>Note number one</li> | ||||||
|  | <li>Note number two</li> | ||||||
|  | </ol> | ||||||
|  | <ac:structured-macro ac:name="note"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p>a<br /> | ||||||
|  | b</p> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <p><strong>Warn (Should not be picked as blockquote type)</strong></p> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <h2 id="Second-Heading">Second Heading</h2> | ||||||
|  | <ac:structured-macro ac:name="warning"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p><strong>"Warn"</strong></p> | ||||||
|  | <ul> | ||||||
|  | <li>Warn bullet 1</li> | ||||||
|  | <li>Warn bullet 2</li> | ||||||
|  | </ul> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <ul> | ||||||
|  | <li>Regular list | ||||||
|  | that runs long</li> | ||||||
|  | </ul> | ||||||
|  | <h2 id="Third-Heading">Third Heading</h2> | ||||||
|  | <ac:structured-macro ac:name="info"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p>Test</p> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <h2 id="Fourth-Heading---Warn-should-not-get-picked-as-block-quote">Fourth Heading - Warn should not get picked as block quote</h2> | ||||||
|  | <ac:structured-macro ac:name="tip"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p><strong>"TIP:"</strong></p> | ||||||
|  | <ol> | ||||||
|  | <li>Note number one</li> | ||||||
|  | <li>Note number two</li> | ||||||
|  | </ol> | ||||||
|  | <ac:structured-macro ac:name="tip"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p>a<br /> | ||||||
|  | b</p> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <p><strong>Warn (Should not be picked as blockquote type)</strong></p> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <h2 id="Simple-Blockquote">Simple Blockquote</h2> | ||||||
|  | <blockquote> | ||||||
|  | <p>This paragraph is a simple blockquote</p> | ||||||
|  | </blockquote> | ||||||
|  | <h2 id="GH-Alerts-Heading">GH Alerts Heading</h2> | ||||||
|  | <h3 id="Note-Type-Alert-Heading">Note Type Alert Heading</h3> | ||||||
|  | <ac:structured-macro ac:name="note"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <ul> | ||||||
|  | <li>Note bullet 1</li> | ||||||
|  | <li>Note bullet 2</li> | ||||||
|  | </ul> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <h3 id="Tip-Type-Alert-Heading">Tip Type Alert Heading</h3> | ||||||
|  | <ac:structured-macro ac:name="tip"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <ul> | ||||||
|  | <li>Tip bullet 1</li> | ||||||
|  | <li>Tip bullet 2</li> | ||||||
|  | </ul> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <h3 id="Warning-Type-Alert-Heading">Warning Type Alert Heading</h3> | ||||||
|  | <ac:structured-macro ac:name="warning"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <ul> | ||||||
|  | <li>Warning bullet 1</li> | ||||||
|  | <li>Warning bullet 2</li> | ||||||
|  | </ul> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <h3 id="Important/Caution-Type-Alert-Heading">Important/Caution Type Alert Heading</h3> | ||||||
|  | <ac:structured-macro ac:name="info"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p><strong>"[!IMPORTANT]"</strong></p> | ||||||
|  | <ul> | ||||||
|  | <li>Important bullet 1</li> | ||||||
|  | <li>Important bullet 2</li> | ||||||
|  | </ul> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
|  | <ac:structured-macro ac:name="warning"><ac:parameter ac:name="icon">true</ac:parameter><ac:rich-text-body> | ||||||
|  | <p><strong>"[!CAUTION]"</strong></p> | ||||||
|  | <ul> | ||||||
|  | <li>Important bullet 1</li> | ||||||
|  | <li>Important bullet 2</li> | ||||||
|  | </ul> | ||||||
|  | </ac:rich-text-body></ac:structured-macro> | ||||||
							
								
								
									
										74
									
								
								testdata/admonitions.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										74
									
								
								testdata/admonitions.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,74 @@ | |||||||
|  | # Main Heading | ||||||
|  | 
 | ||||||
|  | ## First Heading | ||||||
|  | 
 | ||||||
|  | !!! note "NOTES:" | ||||||
|  |     1. Note number one | ||||||
|  |     1. Note number two | ||||||
|  | 
 | ||||||
|  |     !!! note | ||||||
|  |         a   | ||||||
|  |         b | ||||||
|  | 
 | ||||||
|  |     **Warn (Should not be picked as blockquote type)** | ||||||
|  | 
 | ||||||
|  | ## Second Heading | ||||||
|  | 
 | ||||||
|  | !!! warning "Warn" | ||||||
|  |     * Warn bullet 1 | ||||||
|  |     * Warn bullet 2 | ||||||
|  | 
 | ||||||
|  | * Regular list | ||||||
|  |   that runs long | ||||||
|  | 
 | ||||||
|  | ## Third Heading | ||||||
|  | 
 | ||||||
|  | !!! info | ||||||
|  |     Test | ||||||
|  | 
 | ||||||
|  | ## Fourth Heading - Warn should not get picked as block quote | ||||||
|  | 
 | ||||||
|  | !!! tip "TIP:" | ||||||
|  |     1. Note number one | ||||||
|  |     1. Note number two | ||||||
|  | 
 | ||||||
|  |     !!! tip | ||||||
|  |         a   | ||||||
|  |         b | ||||||
|  | 
 | ||||||
|  |     **Warn (Should not be picked as blockquote type)** | ||||||
|  | 
 | ||||||
|  | ## Simple Blockquote | ||||||
|  | 
 | ||||||
|  | > This paragraph is a simple blockquote | ||||||
|  | 
 | ||||||
|  | ## GH Alerts Heading | ||||||
|  | 
 | ||||||
|  | ### Note Type Alert Heading | ||||||
|  | 
 | ||||||
|  | !!! note | ||||||
|  |     * Note bullet 1 | ||||||
|  |     * Note bullet 2 | ||||||
|  | 
 | ||||||
|  | ### Tip Type Alert Heading | ||||||
|  | 
 | ||||||
|  | !!! tip | ||||||
|  |     * Tip bullet 1 | ||||||
|  |     * Tip bullet 2 | ||||||
|  | 
 | ||||||
|  | ### Warning Type Alert Heading | ||||||
|  | 
 | ||||||
|  | !!! warning | ||||||
|  |     * Warning bullet 1 | ||||||
|  |     * Warning bullet 2 | ||||||
|  | 
 | ||||||
|  | ### Important/Caution Type Alert Heading | ||||||
|  | 
 | ||||||
|  | !!! info "[!IMPORTANT]" | ||||||
|  |     * Important bullet 1 | ||||||
|  |     * Important bullet 2 | ||||||
|  | 
 | ||||||
|  | !!! warning "[!CAUTION]" | ||||||
|  |     * Important bullet 1 | ||||||
|  |     * Important bullet 2 | ||||||
|  | 
 | ||||||
| @ -190,7 +190,7 @@ var Flags = []cli.Flag{ | |||||||
| 	&cli.StringSliceFlag{ | 	&cli.StringSliceFlag{ | ||||||
| 		Name:    "features", | 		Name:    "features", | ||||||
| 		Value:   []string{"mermaid"}, | 		Value:   []string{"mermaid"}, | ||||||
| 		Usage:   "Enables optional features. Current features: d2, mermaid", | 		Usage:   "Enables optional features. Current features: d2, mermaid, mkdocsadmonitions", | ||||||
| 		Sources: cli.NewValueSourceChain(cli.EnvVar("MARK_FEATURES"), altsrctoml.TOML("features", altsrc.NewStringPtrSourcer(&filename))), | 		Sources: cli.NewValueSourceChain(cli.EnvVar("MARK_FEATURES"), altsrctoml.TOML("features", altsrc.NewStringPtrSourcer(&filename))), | ||||||
| 	}, | 	}, | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Paul.Glesmann
						Paul.Glesmann