package main import ( "context" "git.dev.alexdunmow.com/block/core/templates/bn" ) // PageData carries everything the page templates need to render. type PageData struct { Title string Slots map[string]string ThemeMode string ThemeCSS string SiteSettings bn.SiteSettingsData PageMeta bn.PageMeta StructuredData string CSSHash string PageviewNonce string EngagementConfig bn.EngagementConfig } // parseKindergartenPageData converts the unstructured doc map the engine // passes in into the strongly-typed PageData used by the templ components. func parseKindergartenPageData(doc map[string]any) PageData { title := "Untitled" if t, ok := doc["title"].(string); ok { title = t } slots := make(map[string]string) if s, ok := doc["slots"].(map[string]string); ok { slots = s } themeCSS := "" if tc, ok := doc["theme_css"].(string); ok { themeCSS = tc } structuredData := "" if sd, ok := doc["structured_data"].(string); ok { structuredData = sd } cssHash := "" if ch, ok := doc["css_hash"].(string); ok { cssHash = ch } pageviewNonce := "" if pn, ok := doc["pageview_nonce"].(string); ok { pageviewNonce = pn } themeMode := "light" if tm, ok := doc["theme_mode"].(string); ok && tm != "" { themeMode = tm } siteSettings := bn.ParseSiteSettings(doc) pageMeta := bn.ParsePageMeta(doc) engagementConfig := bn.ParseEngagementConfig(doc) return PageData{ Title: title, Slots: slots, ThemeMode: themeMode, ThemeCSS: themeCSS, SiteSettings: siteSettings, PageMeta: pageMeta, StructuredData: structuredData, CSSHash: cssHash, PageviewNonce: pageviewNonce, EngagementConfig: engagementConfig, } } // pluginStyles is the canonical list of theme stylesheet URLs each page sends to . var pluginStyles = []string{"/templates/kindergarten/style.css"} // Kindergarten — default template. templ Kindergarten(data PageData) { @bn.Head(bn.HeadData{ Title: data.Title, Settings: data.SiteSettings, PageMeta: data.PageMeta, ThemeMode: data.ThemeMode, ThemeCSS: data.ThemeCSS, PluginStyles: pluginStyles, StructuredData: data.StructuredData, CSSHash: data.CSSHash, PageviewNonce: data.PageviewNonce, EngagementConfig: data.EngagementConfig, }) @bn.AdminBypassBanner(data.SiteSettings)
@templ.Raw(data.Slots["header"])
if main, ok := data.Slots["main"]; ok && main != "" { @templ.Raw(main) } else {
No content blocks assigned to this page.
}
@bn.BodyEnd(data.SiteSettings) } // Kindergarten — landing template with mascot hero + CTA strip. templ KindergartenLanding(data PageData) { @bn.Head(bn.HeadData{ Title: data.Title, Settings: data.SiteSettings, PageMeta: data.PageMeta, ThemeMode: data.ThemeMode, ThemeCSS: data.ThemeCSS, PluginStyles: pluginStyles, StructuredData: data.StructuredData, CSSHash: data.CSSHash, PageviewNonce: data.PageviewNonce, EngagementConfig: data.EngagementConfig, }) @bn.AdminBypassBanner(data.SiteSettings)
@templ.Raw(data.Slots["header"])
@templ.Raw(data.Slots["hero"])
if main, ok := data.Slots["main"]; ok && main != "" { @templ.Raw(main) }
@templ.Raw(data.Slots["cta"])
@bn.BodyEnd(data.SiteSettings) } // Kindergarten — article (storybook reading) template. templ KindergartenArticle(data PageData) { @bn.Head(bn.HeadData{ Title: data.Title, Settings: data.SiteSettings, PageMeta: data.PageMeta, ThemeMode: data.ThemeMode, ThemeCSS: data.ThemeCSS, PluginStyles: pluginStyles, StructuredData: data.StructuredData, CSSHash: data.CSSHash, PageviewNonce: data.PageviewNonce, EngagementConfig: data.EngagementConfig, }) @bn.AdminBypassBanner(data.SiteSettings)
@templ.Raw(data.Slots["header"])
if main, ok := data.Slots["main"]; ok && main != "" {
@templ.Raw(main)
} else {
No content yet — start a story.
}
if aside, ok := data.Slots["aside"]; ok && aside != "" { }
@bn.BodyEnd(data.SiteSettings) } // Kindergarten — full-width gallery / showcase template. templ KindergartenFullWidth(data PageData) { @bn.Head(bn.HeadData{ Title: data.Title, Settings: data.SiteSettings, PageMeta: data.PageMeta, ThemeMode: data.ThemeMode, ThemeCSS: data.ThemeCSS, PluginStyles: pluginStyles, StructuredData: data.StructuredData, CSSHash: data.CSSHash, PageviewNonce: data.PageviewNonce, EngagementConfig: data.EngagementConfig, }) @bn.AdminBypassBanner(data.SiteSettings)
@templ.Raw(data.Slots["header"])
if main, ok := data.Slots["main"]; ok && main != "" { @templ.Raw(main) } else {
No content blocks assigned to this page.
}
@bn.BodyEnd(data.SiteSettings) } // Render functions invoked by the registry. func RenderKindergarten(ctx context.Context, doc map[string]any) templ.Component { return Kindergarten(parseKindergartenPageData(doc)) } func RenderKindergartenLanding(ctx context.Context, doc map[string]any) templ.Component { return KindergartenLanding(parseKindergartenPageData(doc)) } func RenderKindergartenArticle(ctx context.Context, doc map[string]any) templ.Component { return KindergartenArticle(parseKindergartenPageData(doc)) } func RenderKindergartenFullWidth(ctx context.Context, doc map[string]any) templ.Component { return KindergartenFullWidth(parseKindergartenPageData(doc)) }