1
0
mirror of https://github.com/osmarks/mycorrhiza.git synced 2025-01-22 16:16:51 +00:00

Implement the new top bar #78

I decided to not implement dropdowns and stuff yet.

This stuff needs some styling for sure.
This commit is contained in:
Timur Ismagilov 2021-07-14 01:52:33 +05:00
parent 7a6808ed1d
commit f8f4eb92c8
7 changed files with 553 additions and 510 deletions

View File

@ -21,14 +21,9 @@
/* Phones and whatnot */ /* Phones and whatnot */
.layout { display: grid; row-gap: 1rem; } .layout { display: grid; row-gap: 1rem; }
header { width: 100%; margin-bottom: 1rem; } header { width: 100%; margin-bottom: 1rem; }
.header-links__list, .hypha-tabs__flex { margin: 0; padding: 0; display: flex; flex-wrap: wrap; }
.header-links__entry, .hypha-tabs__tab { list-style-type: none; }
.header-links__entry { margin-right: .5rem; line-height: 1.25rem; }
.header-links__search-bar { margin: 0; }
.header-links__entry_user, .header-links__entry_register { font-style:italic; }
.header-links__link { display: inline-block; padding: .25rem; text-decoration: none; }
.hypha-tabs__flex { margin: 0; padding: 0; display: flex; flex-wrap: wrap; }
.hypha-tabs__tab { list-style-type: none; }
.hypha-tabs { padding: 0; margin: 0; } .hypha-tabs { padding: 0; margin: 0; }
.hypha-tabs__tab { margin-right: .5rem; padding: 0; } .hypha-tabs__tab { margin-right: .5rem; padding: 0; }
.hypha-tabs__link { display: inline-block; padding: .25rem; text-decoration: none; } .hypha-tabs__link { display: inline-block; padding: .25rem; text-decoration: none; }
@ -57,17 +52,10 @@ header { width: 100%; margin-bottom: 1rem; }
main { border-radius: .25rem; } main { border-radius: .25rem; }
.layout-card { width: 800px; margin: 0 auto; } .layout-card { width: 800px; margin: 0 auto; }
.header-links { padding: 0; }
.header-links__entry { margin-right: 1.5rem; }
.header-links__entry_user { margin: 0 2rem 0 auto; }
.header-links__entry:nth-of-type(1),
.hypha-tabs { padding: 0; } .hypha-tabs { padding: 0; }
.hypha-tabs__tab { border-radius: .25rem .25rem 0 0; margin-right: 0; } .hypha-tabs__tab { border-radius: .25rem .25rem 0 0; margin-right: 0; }
.hypha-tabs__selection, .hypha-tabs__link { padding: .25rem .5rem; } .hypha-tabs__selection, .hypha-tabs__link { padding: .25rem .5rem; }
.hypha-tabs__tab:nth-of-type(1) { margin-left: 2rem; }
.header-links__entry:nth-of-type(1), .hypha-tabs__tab:nth-of-type(1) { margin-left: 2rem; }
.header-links__search { margin: 0; }
} }
@ -243,8 +231,6 @@ table,
html { background-color: #eee; html { background-color: #eee;
} }
header { background-color: #ddd; } header { background-color: #ddd; }
.header-links__link { color: black; }
.header-links__link:hover { background-color: #eee; }
main { background-color: white; } main { background-color: white; }
.shy-link { color: black; } .shy-link { color: black; }
@ -269,9 +255,7 @@ a:visited, .wikilink_external:visited { color: #ffb86c; }
.wikilink_new, .wikilink_new:visited { color: #dd4444; } .wikilink_new, .wikilink_new:visited { color: #dd4444; }
.subhyphae__link:hover, .sibling-hyphae__link:hover, .backlinks__link:hover { background-color: #444; } .subhyphae__link:hover, .sibling-hyphae__link:hover, .backlinks__link:hover { background-color: #444; }
.header-links__link, .header-links__link:visited,
.prevnext__el, .prevnext__el:visited { color: #ddd; } .prevnext__el, .prevnext__el:visited { color: #ddd; }
.header-links__link:hover { background-color: #444; }
.hypha-tabs__tab a, .hypha-tabs__tab { color: #ddd; background-color: #232323; border: 0; } .hypha-tabs__tab a, .hypha-tabs__tab { color: #ddd; background-color: #232323; border: 0; }
.layout-card__title, .hypha-tabs__tab_active { background-color: #343434; } .layout-card__title, .hypha-tabs__tab_active { background-color: #343434; }
@ -607,4 +591,54 @@ kbd {
} }
.help-topics__list ul { .help-topics__list ul {
padding-left: 1rem; padding-left: 1rem;
}
/*
* Top bar
*/
@media screen and (min-width: 800px) {
.top-bar {
padding: 0;
}
.top-bar ul {
padding: 0;
margin: 0;
}
ul.top-bar__wrapper {
display: grid;
margin: 0 2rem;
}
.top-bar__section {
display: block;
}
.top-bar__section_home {
grid-column: 1 / span 1;
}
.top-bar__section_search {
grid-column: 2 / span 1;
}
.top-bar__section_auth {
grid-column: 3 / span 1;
}
.top-bar__section_highlights {
grid-column: 1 / span 3;
}
.top-bar__search-bar {
width: 100%;
}
.auth-links {
display: flex;
justify-content: flex-end;
}
.auth-links__box {
display: block;
}
.top-bar__highlights {
display: flex;
}
.top-bar__highlight {
display: block;
}
} }

View File

@ -308,11 +308,11 @@
// Common shortcuts // Common shortcuts
pageShortcuts.group('Common', function () { pageShortcuts.group('Common', function () {
this.bindCollection('g', '.header-links__link', 'First 9 header links', 'Header link'); this.bindCollection('g', '.top-bar__highlight-link', 'First 9 header links', 'Header link');
this.bindLink('g h', '/', 'Home'); this.bindLink('g h', '/', 'Home');
this.bindLink('g l', '/list/', 'List of hyphae'); this.bindLink('g l', '/list/', 'List of hyphae');
this.bindLink('g r', '/recent-changes/', 'Recent changes'); this.bindLink('g r', '/recent-changes/', 'Recent changes');
this.bindElement('g u', '.header-links__entry_user .header-links__link', 'Your profiles hypha'); this.bindElement('g u', '.auth-links__user-link', 'Your profiles hypha');
}); });
if (!onEditPage) { if (!onEditPage) {

View File

@ -70,7 +70,7 @@ function insertTimeUTC() {
} }
function insertUserlink() { function insertUserlink() {
const userlink = document.querySelector('.header-links__entry_user a') const userlink = document.querySelector('.auth-links__user-link')
const userHypha = userlink.getAttribute('href').substring(7) // no /hypha/ const userHypha = userlink.getAttribute('href').substring(7) // no /hypha/
textInserter('[[' + userHypha + ']]')() textInserter('[[' + userHypha + ']]')()
} }

View File

@ -1,8 +1,6 @@
{% import "net/http" %} {% import "net/http" %}
{% import "strings" %} {% import "strings" %}
{% import "github.com/bouncepaw/mycorrhiza/cfg" %}
{% import "github.com/bouncepaw/mycorrhiza/user" %} {% import "github.com/bouncepaw/mycorrhiza/user" %}
{% import "github.com/bouncepaw/mycorrhiza/util" %}
This is the <nav> seen on top of many pages. This is the <nav> seen on top of many pages.
{% code {% code
@ -47,23 +45,6 @@ var navEntries = []navEntry{
</nav> </nav>
{% endfunc %} {% endfunc %}
{% func UserMenuHTML(u *user.User) %}
{% if cfg.UseAuth %}
<li class="header-links__entry header-links__entry_user">
{% if u.Group == "anon" %}
<a href="/login" class="header-links__link">Login</a>
{% else %}
<a href="/hypha/{%s cfg.UserHypha %}/{%s u.Name %}" class="header-links__link">{%s util.BeautifulName(u.Name) %}</a>
{% endif %}
</li>
{% endif %}
{% if cfg.UseAuth && cfg.AllowRegistration && u.Group == "anon" %}
<li class="header-links__entry header-links__entry_register">
<a href="/register" class="header-links__link">Register</a>
</li>
{% endif %}
{% endfunc %}
{% func siblingHyphaeHTML(siblings string) %} {% func siblingHyphaeHTML(siblings string) %}
<aside class="sibling-hyphae layout-card"> <aside class="sibling-hyphae layout-card">
<h2 class="sibling-hyphae__title layout-card__title">Sibling hyphae</h2> <h2 class="sibling-hyphae__title layout-card__title">Sibling hyphae</h2>

View File

@ -11,30 +11,24 @@ import "net/http"
import "strings" import "strings"
//line views/nav.qtpl:3 //line views/nav.qtpl:3
import "github.com/bouncepaw/mycorrhiza/cfg"
//line views/nav.qtpl:4
import "github.com/bouncepaw/mycorrhiza/user" import "github.com/bouncepaw/mycorrhiza/user"
//line views/nav.qtpl:5
import "github.com/bouncepaw/mycorrhiza/util"
// This is the <nav> seen on top of many pages. // This is the <nav> seen on top of many pages.
//line views/nav.qtpl:8 //line views/nav.qtpl:6
import ( import (
qtio422016 "io" qtio422016 "io"
qt422016 "github.com/valyala/quicktemplate" qt422016 "github.com/valyala/quicktemplate"
) )
//line views/nav.qtpl:8 //line views/nav.qtpl:6
var ( var (
_ = qtio422016.Copy _ = qtio422016.Copy
_ = qt422016.AcquireByteBuffer _ = qt422016.AcquireByteBuffer
) )
//line views/nav.qtpl:9 //line views/nav.qtpl:7
type navEntry struct { type navEntry struct {
path string path string
title string title string
@ -51,281 +45,193 @@ var navEntries = []navEntry{
{"text", "Raw text"}, {"text", "Raw text"},
} }
//line views/nav.qtpl:25 //line views/nav.qtpl:23
func StreamNavHTML(qw422016 *qt422016.Writer, rq *http.Request, hyphaName, navType string, revisionHash ...string) { func StreamNavHTML(qw422016 *qt422016.Writer, rq *http.Request, hyphaName, navType string, revisionHash ...string) {
//line views/nav.qtpl:25 //line views/nav.qtpl:23
qw422016.N().S(` qw422016.N().S(`
`) `)
//line views/nav.qtpl:27 //line views/nav.qtpl:25
u := user.FromRequest(rq) u := user.FromRequest(rq)
//line views/nav.qtpl:28 //line views/nav.qtpl:26
qw422016.N().S(` qw422016.N().S(`
<nav class="hypha-tabs main-width"> <nav class="hypha-tabs main-width">
<ul class="hypha-tabs__flex"> <ul class="hypha-tabs__flex">
`) `)
//line views/nav.qtpl:31 //line views/nav.qtpl:29
for _, entry := range navEntries { for _, entry := range navEntries {
//line views/nav.qtpl:32 //line views/nav.qtpl:30
if navType == "revision" && entry.path == "revision" { if navType == "revision" && entry.path == "revision" {
//line views/nav.qtpl:30
qw422016.N().S(` <li class="hypha-tabs__tab hypha-tabs__tab_active">
<span class="hypha-tabs__selection">`)
//line views/nav.qtpl:32 //line views/nav.qtpl:32
qw422016.N().S(` <li class="hypha-tabs__tab hypha-tabs__tab_active">
<span class="hypha-tabs__selection">`)
//line views/nav.qtpl:34
qw422016.E().S(revisionHash[0]) qw422016.E().S(revisionHash[0])
//line views/nav.qtpl:34 //line views/nav.qtpl:32
qw422016.N().S(`</span> qw422016.N().S(`</span>
</li> </li>
`) `)
//line views/nav.qtpl:36 //line views/nav.qtpl:34
} else if navType == entry.path { } else if navType == entry.path {
//line views/nav.qtpl:36 //line views/nav.qtpl:34
qw422016.N().S(` <li class="hypha-tabs__tab hypha-tabs__tab_active"> qw422016.N().S(` <li class="hypha-tabs__tab hypha-tabs__tab_active">
<span class="hypha-tabs__selection">`) <span class="hypha-tabs__selection">`)
//line views/nav.qtpl:38 //line views/nav.qtpl:36
qw422016.E().S(entry.title) qw422016.E().S(entry.title)
//line views/nav.qtpl:38 //line views/nav.qtpl:36
qw422016.N().S(`</span> qw422016.N().S(`</span>
</li> </li>
`) `)
//line views/nav.qtpl:40 //line views/nav.qtpl:38
} else if entry.path != "revision" && u.CanProceed(entry.path) { } else if entry.path != "revision" && u.CanProceed(entry.path) {
//line views/nav.qtpl:40 //line views/nav.qtpl:38
qw422016.N().S(` <li class="hypha-tabs__tab"> qw422016.N().S(` <li class="hypha-tabs__tab">
<a class="hypha-tabs__link" href="/`) <a class="hypha-tabs__link" href="/`)
//line views/nav.qtpl:42 //line views/nav.qtpl:40
qw422016.E().S(entry.path) qw422016.E().S(entry.path)
//line views/nav.qtpl:42 //line views/nav.qtpl:40
qw422016.N().S(`/`) qw422016.N().S(`/`)
//line views/nav.qtpl:42 //line views/nav.qtpl:40
qw422016.E().S(hyphaName) qw422016.E().S(hyphaName)
//line views/nav.qtpl:42 //line views/nav.qtpl:40
qw422016.N().S(`">`) qw422016.N().S(`">`)
//line views/nav.qtpl:42 //line views/nav.qtpl:40
qw422016.E().S(entry.title) qw422016.E().S(entry.title)
//line views/nav.qtpl:42 //line views/nav.qtpl:40
qw422016.N().S(`</a> qw422016.N().S(`</a>
</li> </li>
`) `)
//line views/nav.qtpl:44 //line views/nav.qtpl:42
} }
//line views/nav.qtpl:45 //line views/nav.qtpl:43
} }
//line views/nav.qtpl:45 //line views/nav.qtpl:43
qw422016.N().S(` </ul> qw422016.N().S(` </ul>
</nav> </nav>
`) `)
//line views/nav.qtpl:48 //line views/nav.qtpl:46
} }
//line views/nav.qtpl:48 //line views/nav.qtpl:46
func WriteNavHTML(qq422016 qtio422016.Writer, rq *http.Request, hyphaName, navType string, revisionHash ...string) { func WriteNavHTML(qq422016 qtio422016.Writer, rq *http.Request, hyphaName, navType string, revisionHash ...string) {
//line views/nav.qtpl:48 //line views/nav.qtpl:46
qw422016 := qt422016.AcquireWriter(qq422016) qw422016 := qt422016.AcquireWriter(qq422016)
//line views/nav.qtpl:48 //line views/nav.qtpl:46
StreamNavHTML(qw422016, rq, hyphaName, navType, revisionHash...) StreamNavHTML(qw422016, rq, hyphaName, navType, revisionHash...)
//line views/nav.qtpl:48 //line views/nav.qtpl:46
qt422016.ReleaseWriter(qw422016) qt422016.ReleaseWriter(qw422016)
//line views/nav.qtpl:48 //line views/nav.qtpl:46
} }
//line views/nav.qtpl:48 //line views/nav.qtpl:46
func NavHTML(rq *http.Request, hyphaName, navType string, revisionHash ...string) string { func NavHTML(rq *http.Request, hyphaName, navType string, revisionHash ...string) string {
//line views/nav.qtpl:48 //line views/nav.qtpl:46
qb422016 := qt422016.AcquireByteBuffer() qb422016 := qt422016.AcquireByteBuffer()
//line views/nav.qtpl:48 //line views/nav.qtpl:46
WriteNavHTML(qb422016, rq, hyphaName, navType, revisionHash...) WriteNavHTML(qb422016, rq, hyphaName, navType, revisionHash...)
//line views/nav.qtpl:48 //line views/nav.qtpl:46
qs422016 := string(qb422016.B) qs422016 := string(qb422016.B)
//line views/nav.qtpl:48 //line views/nav.qtpl:46
qt422016.ReleaseByteBuffer(qb422016) qt422016.ReleaseByteBuffer(qb422016)
//line views/nav.qtpl:48 //line views/nav.qtpl:46
return qs422016 return qs422016
//line views/nav.qtpl:46
}
//line views/nav.qtpl:48 //line views/nav.qtpl:48
}
//line views/nav.qtpl:50
func StreamUserMenuHTML(qw422016 *qt422016.Writer, u *user.User) {
//line views/nav.qtpl:50
qw422016.N().S(`
`)
//line views/nav.qtpl:51
if cfg.UseAuth {
//line views/nav.qtpl:51
qw422016.N().S(`
<li class="header-links__entry header-links__entry_user">
`)
//line views/nav.qtpl:53
if u.Group == "anon" {
//line views/nav.qtpl:53
qw422016.N().S(`
<a href="/login" class="header-links__link">Login</a>
`)
//line views/nav.qtpl:55
} else {
//line views/nav.qtpl:55
qw422016.N().S(`
<a href="/hypha/`)
//line views/nav.qtpl:56
qw422016.E().S(cfg.UserHypha)
//line views/nav.qtpl:56
qw422016.N().S(`/`)
//line views/nav.qtpl:56
qw422016.E().S(u.Name)
//line views/nav.qtpl:56
qw422016.N().S(`" class="header-links__link">`)
//line views/nav.qtpl:56
qw422016.E().S(util.BeautifulName(u.Name))
//line views/nav.qtpl:56
qw422016.N().S(`</a>
`)
//line views/nav.qtpl:57
}
//line views/nav.qtpl:57
qw422016.N().S(`
</li>
`)
//line views/nav.qtpl:59
}
//line views/nav.qtpl:59
qw422016.N().S(`
`)
//line views/nav.qtpl:60
if cfg.UseAuth && cfg.AllowRegistration && u.Group == "anon" {
//line views/nav.qtpl:60
qw422016.N().S(`
<li class="header-links__entry header-links__entry_register">
<a href="/register" class="header-links__link">Register</a>
</li>
`)
//line views/nav.qtpl:64
}
//line views/nav.qtpl:64
qw422016.N().S(`
`)
//line views/nav.qtpl:65
}
//line views/nav.qtpl:65
func WriteUserMenuHTML(qq422016 qtio422016.Writer, u *user.User) {
//line views/nav.qtpl:65
qw422016 := qt422016.AcquireWriter(qq422016)
//line views/nav.qtpl:65
StreamUserMenuHTML(qw422016, u)
//line views/nav.qtpl:65
qt422016.ReleaseWriter(qw422016)
//line views/nav.qtpl:65
}
//line views/nav.qtpl:65
func UserMenuHTML(u *user.User) string {
//line views/nav.qtpl:65
qb422016 := qt422016.AcquireByteBuffer()
//line views/nav.qtpl:65
WriteUserMenuHTML(qb422016, u)
//line views/nav.qtpl:65
qs422016 := string(qb422016.B)
//line views/nav.qtpl:65
qt422016.ReleaseByteBuffer(qb422016)
//line views/nav.qtpl:65
return qs422016
//line views/nav.qtpl:65
}
//line views/nav.qtpl:67
func streamsiblingHyphaeHTML(qw422016 *qt422016.Writer, siblings string) { func streamsiblingHyphaeHTML(qw422016 *qt422016.Writer, siblings string) {
//line views/nav.qtpl:67 //line views/nav.qtpl:48
qw422016.N().S(` qw422016.N().S(`
<aside class="sibling-hyphae layout-card"> <aside class="sibling-hyphae layout-card">
<h2 class="sibling-hyphae__title layout-card__title">Sibling hyphae</h2> <h2 class="sibling-hyphae__title layout-card__title">Sibling hyphae</h2>
`) `)
//line views/nav.qtpl:70 //line views/nav.qtpl:51
qw422016.N().S(siblings) qw422016.N().S(siblings)
//line views/nav.qtpl:70 //line views/nav.qtpl:51
qw422016.N().S(` qw422016.N().S(`
</aside> </aside>
`) `)
//line views/nav.qtpl:72 //line views/nav.qtpl:53
} }
//line views/nav.qtpl:72 //line views/nav.qtpl:53
func writesiblingHyphaeHTML(qq422016 qtio422016.Writer, siblings string) { func writesiblingHyphaeHTML(qq422016 qtio422016.Writer, siblings string) {
//line views/nav.qtpl:72 //line views/nav.qtpl:53
qw422016 := qt422016.AcquireWriter(qq422016) qw422016 := qt422016.AcquireWriter(qq422016)
//line views/nav.qtpl:72 //line views/nav.qtpl:53
streamsiblingHyphaeHTML(qw422016, siblings) streamsiblingHyphaeHTML(qw422016, siblings)
//line views/nav.qtpl:72 //line views/nav.qtpl:53
qt422016.ReleaseWriter(qw422016) qt422016.ReleaseWriter(qw422016)
//line views/nav.qtpl:72 //line views/nav.qtpl:53
} }
//line views/nav.qtpl:72 //line views/nav.qtpl:53
func siblingHyphaeHTML(siblings string) string { func siblingHyphaeHTML(siblings string) string {
//line views/nav.qtpl:72 //line views/nav.qtpl:53
qb422016 := qt422016.AcquireByteBuffer() qb422016 := qt422016.AcquireByteBuffer()
//line views/nav.qtpl:72 //line views/nav.qtpl:53
writesiblingHyphaeHTML(qb422016, siblings) writesiblingHyphaeHTML(qb422016, siblings)
//line views/nav.qtpl:72 //line views/nav.qtpl:53
qs422016 := string(qb422016.B) qs422016 := string(qb422016.B)
//line views/nav.qtpl:72 //line views/nav.qtpl:53
qt422016.ReleaseByteBuffer(qb422016) qt422016.ReleaseByteBuffer(qb422016)
//line views/nav.qtpl:72 //line views/nav.qtpl:53
return qs422016 return qs422016
//line views/nav.qtpl:72 //line views/nav.qtpl:53
} }
//line views/nav.qtpl:74 //line views/nav.qtpl:55
func StreamSubhyphaeHTML(qw422016 *qt422016.Writer, subhyphae string) { func StreamSubhyphaeHTML(qw422016 *qt422016.Writer, subhyphae string) {
//line views/nav.qtpl:74 //line views/nav.qtpl:55
qw422016.N().S(` qw422016.N().S(`
`) `)
//line views/nav.qtpl:75 //line views/nav.qtpl:56
if strings.TrimSpace(subhyphae) != "" { if strings.TrimSpace(subhyphae) != "" {
//line views/nav.qtpl:75 //line views/nav.qtpl:56
qw422016.N().S(` qw422016.N().S(`
<section class="subhyphae"> <section class="subhyphae">
<h2 class="subhyphae__title">Subhyphae</h2> <h2 class="subhyphae__title">Subhyphae</h2>
<nav class="subhyphae__nav"> <nav class="subhyphae__nav">
<ul class="subhyphae__list"> <ul class="subhyphae__list">
`) `)
//line views/nav.qtpl:80 //line views/nav.qtpl:61
qw422016.N().S(subhyphae) qw422016.N().S(subhyphae)
//line views/nav.qtpl:80 //line views/nav.qtpl:61
qw422016.N().S(` qw422016.N().S(`
</ul> </ul>
</nav> </nav>
</section> </section>
`) `)
//line views/nav.qtpl:84 //line views/nav.qtpl:65
} }
//line views/nav.qtpl:84 //line views/nav.qtpl:65
qw422016.N().S(` qw422016.N().S(`
`) `)
//line views/nav.qtpl:85 //line views/nav.qtpl:66
} }
//line views/nav.qtpl:85 //line views/nav.qtpl:66
func WriteSubhyphaeHTML(qq422016 qtio422016.Writer, subhyphae string) { func WriteSubhyphaeHTML(qq422016 qtio422016.Writer, subhyphae string) {
//line views/nav.qtpl:85 //line views/nav.qtpl:66
qw422016 := qt422016.AcquireWriter(qq422016) qw422016 := qt422016.AcquireWriter(qq422016)
//line views/nav.qtpl:85 //line views/nav.qtpl:66
StreamSubhyphaeHTML(qw422016, subhyphae) StreamSubhyphaeHTML(qw422016, subhyphae)
//line views/nav.qtpl:85 //line views/nav.qtpl:66
qt422016.ReleaseWriter(qw422016) qt422016.ReleaseWriter(qw422016)
//line views/nav.qtpl:85 //line views/nav.qtpl:66
} }
//line views/nav.qtpl:85 //line views/nav.qtpl:66
func SubhyphaeHTML(subhyphae string) string { func SubhyphaeHTML(subhyphae string) string {
//line views/nav.qtpl:85 //line views/nav.qtpl:66
qb422016 := qt422016.AcquireByteBuffer() qb422016 := qt422016.AcquireByteBuffer()
//line views/nav.qtpl:85 //line views/nav.qtpl:66
WriteSubhyphaeHTML(qb422016, subhyphae) WriteSubhyphaeHTML(qb422016, subhyphae)
//line views/nav.qtpl:85 //line views/nav.qtpl:66
qs422016 := string(qb422016.B) qs422016 := string(qb422016.B)
//line views/nav.qtpl:85 //line views/nav.qtpl:66
qt422016.ReleaseByteBuffer(qb422016) qt422016.ReleaseByteBuffer(qb422016)
//line views/nav.qtpl:85 //line views/nav.qtpl:66
return qs422016 return qs422016
//line views/nav.qtpl:85 //line views/nav.qtpl:66
} }

View File

@ -18,17 +18,50 @@
</head> </head>
<body> <body>
<header> <header>
<nav class="header-links main-width"> <nav class="main-width top-bar">
<ul class="header-links__list"> <ul class="top-bar__wrapper">
{%- for _, link := range cfg.HeaderLinks -%} <li class="top-bar__section top-bar__section_home">
<li class="header-links__entry"><a class="header-links__link" href="{%s link.Href %}">{%s link.Display %}</a></li> <a class="top-bar__home-link" href="/">{%s cfg.WikiName %}</a>
{%- endfor -%} </li>
<li class="header-links__entry header-links__entry_search"> <li class="top-bar__section top-bar__section_search">
<form class="header-links__search" method="GET" action="/title-search"> <form class="top-bar__search" method="GET" action="/title-search">
<input type="text" name="q" placeholder="Title search" class="header-links__search-bar"> <input type="text" name="q" placeholder="Title search" class="top-bar__search-bar">
</form> </form>
</li> </li>
{%s= UserMenuHTML(u) %} {% if cfg.UseAuth %}
<li class="top-bar__section top-bar__section_auth">
<ul class="top-bar__auth auth-links">
<li class="auth-links__box auth-links__user-box">
{% if u.Group == "anon" %}
<a href="/login" class="auth-links__login-link">Login</a>
{% else %}
<a href="/hypha/{%s cfg.UserHypha %}/{%s u.Name %}" class="auth-links__user-link">{%s util.BeautifulName(u.Name) %}</a>
{% endif %}
</li>
{% if cfg.AllowRegistration && u.Group == "anon" %}
<li class="auth-links__box auth-links__register-box">
<a href="/register" class="auth-links__register-link">Register</a>
</li>
{% endif %}
{% if u.Group == "admin" %}
<li class="auth-links__box auth-links__admin-box">
<a href="/admin" class="auth-links__admin-link">Admin panel</a>
</li>
{% endif %}
</ul>
</li>
{% endif %}
<li class="top-bar__section top-bar__section_highlights">
<ul class="top-bar__highlights">
{%- for _, link := range cfg.HeaderLinks -%}
{% if link.Href != "/" %}
<li class="top-bar__highlight">
<a class="top-bar__highlight-link" href="{%s link.Href %}">{%s link.Display %}</a>
</li>
{% endif %}
{%- endfor -%}
</ul>
</li>
</ul> </ul>
</nav> </nav>
</header> </header>

File diff suppressed because it is too large Load Diff