2021-05-11 08:33:00 +00:00
package cfg
2021-07-05 04:22:17 +00:00
// See https://mycorrhiza.wiki/hypha/configuration/header
2021-05-11 08:33:00 +00:00
import (
2021-12-19 14:35:18 +00:00
"github.com/bouncepaw/mycomarkup/v3"
2021-10-05 20:10:28 +00:00
"github.com/bouncepaw/mycomarkup/v3/blocks"
2021-12-19 14:35:18 +00:00
"github.com/bouncepaw/mycomarkup/v3/mycocontext"
2021-05-11 08:33:00 +00:00
)
// 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" } ,
2021-07-24 19:16:49 +00:00
{ "/help" , "Help" } ,
2021-05-11 08:33:00 +00:00
}
}
2021-05-24 09:33:57 +00:00
// ParseHeaderLinks extracts all rocketlinks from the given text and saves them as header links.
func ParseHeaderLinks ( text string ) {
2021-12-19 14:35:18 +00:00
ctx , _ := mycocontext . ContextFromStringInput ( "" , text )
// 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 ( ) ,
} )
}
2021-05-11 08:33:00 +00:00
}
2021-12-19 14:35:18 +00:00
} )
2021-05-11 08:33:00 +00:00
}
// 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
}