mirror of
https://github.com/osmarks/mycorrhiza.git
synced 2025-01-22 08:06:52 +00:00
49 lines
1.6 KiB
Go
49 lines
1.6 KiB
Go
package cfg
|
|
|
|
import (
|
|
"github.com/bouncepaw/mycomarkup/v4"
|
|
"github.com/bouncepaw/mycomarkup/v4/blocks"
|
|
"github.com/bouncepaw/mycomarkup/v4/mycocontext"
|
|
"github.com/bouncepaw/mycomarkup/v4/options"
|
|
)
|
|
|
|
// HeaderLinks is a list off current header links. Feel free to iterate it directly but do not modify it by yourself. Call ParseHeaderLinks if you need to set new header links.
|
|
var HeaderLinks []HeaderLink
|
|
|
|
// SetDefaultHeaderLinks sets the header links to the default list of: home hypha, recent changes, hyphae list, random hypha.
|
|
func SetDefaultHeaderLinks() {
|
|
HeaderLinks = []HeaderLink{
|
|
{"/recent-changes", "Recent changes"},
|
|
{"/list", "All hyphae"},
|
|
{"/random", "Random"},
|
|
{"/help", "Help"},
|
|
{"/category", "Categories"},
|
|
}
|
|
}
|
|
|
|
// ParseHeaderLinks extracts all rocketlinks from the given text and saves them as header links.
|
|
func ParseHeaderLinks(text string) {
|
|
HeaderLinks = []HeaderLink{}
|
|
ctx, _ := mycocontext.ContextFromStringInput(text, options.Options{}.FillTheRest())
|
|
// We call for side-effects
|
|
_ = mycomarkup.BlockTree(ctx, func(block blocks.Block) {
|
|
switch launchpad := block.(type) {
|
|
case blocks.LaunchPad:
|
|
for _, rocket := range launchpad.Rockets {
|
|
HeaderLinks = append(HeaderLinks, HeaderLink{
|
|
Href: rocket.Href(),
|
|
Display: rocket.Display(),
|
|
})
|
|
}
|
|
}
|
|
})
|
|
}
|
|
|
|
// HeaderLink represents a header link. Header links are the links shown in the top gray bar.
|
|
type HeaderLink struct {
|
|
// Href is the URL of the link. It goes <a href="here">...</a>.
|
|
Href string
|
|
// Display is what is shown when the link is rendered. It goes <a href="...">here</a>.
|
|
Display string
|
|
}
|