Browse Source
Changed tags to allow same-name taggs with different categories, added tag list
master
Changed tags to allow same-name taggs with different categories, added tag list
master
Gisle Aune
7 years ago
10 changed files with 220 additions and 13 deletions
-
46controllers/listcontroller.go
-
34controllers/tagcontroller.go
-
1main.go
-
45model/tag.go
-
1view/renderer.go
-
2view/templates/base/default.tmpl
-
6view/templates/index.tmpl
-
4view/templates/page/view.tmpl
-
48view/templates/tags/list.tmpl
-
46viewmodel/taglist.go
@ -0,0 +1,34 @@ |
|||
package controllers |
|||
|
|||
import ( |
|||
"net/http" |
|||
|
|||
"git.aiterp.net/AiteRP/aitestory/view" |
|||
"git.aiterp.net/AiteRP/aitestory/viewmodel" |
|||
|
|||
"git.aiterp.net/AiteRP/aitestory/model" |
|||
"git.aiterp.net/gisle/wrouter" |
|||
"git.aiterp.net/gisle/wrouter/auth" |
|||
) |
|||
|
|||
// TagController serves and handles the tag managment pages
|
|||
var TagController = wrouter.Router{} |
|||
|
|||
func tagList(path string, w http.ResponseWriter, req *http.Request, user *auth.User) bool { |
|||
//var err error
|
|||
if (req.Method != "GET" && req.Method != "POST") || len(req.URL.Path) > len(path) { |
|||
return false |
|||
} |
|||
|
|||
tl := viewmodel.TagList{} |
|||
tl.Tags, _ = model.ListTags() |
|||
tl.Setup(user) |
|||
|
|||
view.Render(w, "tags/list", 200, tl) |
|||
|
|||
return true |
|||
} |
|||
|
|||
func init() { |
|||
TagController.Function("/", tagList) |
|||
} |
@ -0,0 +1,48 @@ |
|||
{{ define "content" }} |
|||
<article> |
|||
<h1>All Tags</h1> |
|||
|
|||
<div class="tag-list"> |
|||
{{ range $tagHeader, $tags := .Map }} |
|||
<div class="tl-item"> |
|||
<h2>{{ $tagHeader }}</h2> |
|||
<ul> |
|||
{{ range $tags }} |
|||
<li><a class="ttype-{{.Type | tolower }}" href="/{{.Type}}/{{.Name}}">{{ .Name }}</a></li> |
|||
{{ end }} |
|||
</ul> |
|||
</div> |
|||
{{ end }} |
|||
</div> |
|||
|
|||
|
|||
</article> |
|||
{{ end }} |
|||
|
|||
{{ define "menu" }} |
|||
<a href="/"><h1>Tags</h1></a> |
|||
|
|||
<ul> |
|||
<li><a href="/"><div class="mg-icon"><</div><div class="mg-label">Back</div></a></li> |
|||
</ul> |
|||
|
|||
{{ if $.User.LoggedIn }} |
|||
<ul> |
|||
<li><a href="/page/create"><div class="mg-icon">+</div><div class="mg-label">Create</div></a></li> |
|||
</ul> |
|||
|
|||
<ul> |
|||
<li><a href="/user/logout"><div class="mg-icon">A</div><div class="mg-label">Logout</div></a></li> |
|||
</ul> |
|||
{{ else }} |
|||
<ul> |
|||
<li><a href="/user/login"><div class="mg-icon">A</div><div class="mg-label">Login</div></a></li> |
|||
</ul> |
|||
{{ end }} |
|||
|
|||
|
|||
{{ end }} |
|||
|
|||
{{ define "head" }} |
|||
|
|||
{{ end }} |
@ -0,0 +1,46 @@ |
|||
package viewmodel |
|||
|
|||
import ( |
|||
"fmt" |
|||
|
|||
"git.aiterp.net/AiteRP/aitestory/model" |
|||
"git.aiterp.net/gisle/wrouter/auth" |
|||
) |
|||
|
|||
// TagList is a view model for rendering the tag lists.
|
|||
type TagList struct { |
|||
Base |
|||
Type string |
|||
Tags []model.Tag |
|||
TagCategories []string |
|||
|
|||
tagMap map[string][]model.Tag |
|||
} |
|||
|
|||
// Map lazy-loads the map of tags, which is only
|
|||
// used when listing all of them.
|
|||
func (tl TagList) Map() map[string][]model.Tag { |
|||
// Set up the map
|
|||
tl.tagMap = make(map[string][]model.Tag, len(model.TagTypes)) |
|||
for _, tagType := range model.TagTypes { |
|||
tl.tagMap[tagType] = make([]model.Tag, 0, 64) |
|||
} |
|||
|
|||
// Organize
|
|||
for _, tag := range tl.Tags { |
|||
tl.tagMap[tag.Type] = append(tl.tagMap[tag.Type], tag) |
|||
} |
|||
|
|||
return tl.tagMap |
|||
} |
|||
|
|||
// Setup sets up the page model and the base, and should
|
|||
// be run after the details have been filled in.
|
|||
func (tl *TagList) Setup(user *auth.User) { |
|||
title := tl.Type |
|||
if tl.Type != "" { |
|||
title = "All" |
|||
} |
|||
|
|||
tl.setupBase(user, fmt.Sprintf("%s Tags", title)) |
|||
} |
Write
Preview
Loading…
Cancel
Save
Reference in new issue