Added more filters for editors

This commit is contained in:
Eduard Urbach 2020-02-22 17:07:47 +09:00
parent 8cf76481bf
commit 43c978ed8b
Signed by: akyoto
GPG Key ID: C874F672B1AF20C0
6 changed files with 131 additions and 0 deletions

View File

@ -64,6 +64,7 @@ component EditorTabs(url string, user *arn.User)
Tab("Status", "calendar-check-o", "/editor/anime/details/status" + user.Settings().Editor.Filter.Suffix()) Tab("Status", "calendar-check-o", "/editor/anime/details/status" + user.Settings().Editor.Filter.Suffix())
Tab("Trailers", "youtube", "/editor/anime/details/trailers" + user.Settings().Editor.Filter.Suffix()) Tab("Trailers", "youtube", "/editor/anime/details/trailers" + user.Settings().Editor.Filter.Suffix())
Tab("Start date", "calendar", "/editor/anime/details/startdate" + user.Settings().Editor.Filter.Suffix()) Tab("Start date", "calendar", "/editor/anime/details/startdate" + user.Settings().Editor.Filter.Suffix())
Tab("End date", "calendar", "/editor/anime/details/enddate" + user.Settings().Editor.Filter.Suffix())
Tab("Ep. Length", "clock-o", "/editor/anime/details/episodelength" + user.Settings().Editor.Filter.Suffix()) Tab("Ep. Length", "clock-o", "/editor/anime/details/episodelength" + user.Settings().Editor.Filter.Suffix())
Tab("Source", "book", "/editor/anime/details/source" + user.Settings().Editor.Filter.Suffix()) Tab("Source", "book", "/editor/anime/details/source" + user.Settings().Editor.Filter.Suffix())

View File

@ -0,0 +1,22 @@
package filteranime
import (
"time"
"github.com/aerogo/aero"
"github.com/animenotifier/notify.moe/arn"
"github.com/animenotifier/notify.moe/arn/validate"
)
// EndDate ...
func EndDate(ctx aero.Context) error {
return editorList(
ctx,
"Anime without a valid end date",
func(anime *arn.Anime) bool {
_, err := time.Parse(validate.DateFormat, anime.EndDate)
return err != nil
},
nil,
)
}

View File

@ -0,0 +1,55 @@
package filtercharacters
import (
"net/http"
"github.com/aerogo/aero"
"github.com/animenotifier/notify.moe/arn"
"github.com/animenotifier/notify.moe/components"
)
const maxCharacterEntries = 70
// characterList renders the characters with the given filter for editors.
func characterList(ctx aero.Context, title string, filter func(*arn.Character) bool, searchLink func(*arn.Character) string) error {
user := arn.GetUserFromContext(ctx)
if user == nil || (user.Role != "admin" && user.Role != "editor") {
return ctx.Error(http.StatusUnauthorized, "Not authorized")
}
characters, count := filterCharacters(ctx, user, filter)
return ctx.HTML(components.CharacterEditorListFull(
title,
characters,
count,
searchLink,
user,
))
}
// filterCharacters filters anime by the given filter function and
// additionally applies year and types filters if specified.
func filterCharacters(ctx aero.Context, user *arn.User, filter func(*arn.Character) bool) ([]*arn.Character, int) {
// Filter
characters := arn.FilterCharacters(func(character *arn.Character) bool {
if character.IsDraft {
return false
}
return filter(character)
})
// Sort
arn.SortCharactersByLikes(characters)
// Limit
count := len(characters)
if count > maxCharacterEntries {
characters = characters[:maxCharacterEntries]
}
return characters, count
}

View File

@ -0,0 +1,30 @@
component CharacterEditorListFull(title string, missing []*arn.Character, count int, generateSearchLink func(*arn.Character) string, user *arn.User)
.corner-buttons-left
a.button(href="/editor")
RawIcon("arrow-left")
h1.editor-list-page-title.mountable= title
footer.footer.editor-list-entry-count.mountable= strconv.Itoa(count) + " characters"
CharacterEditorList(missing, generateSearchLink)
component CharacterEditorList(characters []*arn.Character, generateSearchLink func(*arn.Character) string)
table.editor-list
thead
tr.mountable
th Name
if generateSearchLink != nil
th Tools
tbody
each character in characters
tr.mountable
td
a(href=character.Link(), target="_blank", rel="noopener")
if character.HasImage()
img.character-list-item-image.lazy(data-src=character.ImageLink("small"), data-webp="true", data-color=character.AverageColor(), alt=character.Name.Canonical)
span= character.Name.Canonical
if generateSearchLink != nil
td
a(href=generateSearchLink(character), target="_blank", rel="noopener") 🔍

View File

@ -0,0 +1,18 @@
package filtercharacters
import (
"github.com/aerogo/aero"
"github.com/animenotifier/notify.moe/arn"
)
// NoImage ...
func NoImage(ctx aero.Context) error {
return characterList(
ctx,
"Characters without an image",
func(character *arn.Character) bool {
return !character.HasImage()
},
nil,
)
}

View File

@ -6,6 +6,7 @@ import (
"github.com/animenotifier/notify.moe/pages/editlog" "github.com/animenotifier/notify.moe/pages/editlog"
"github.com/animenotifier/notify.moe/pages/editor" "github.com/animenotifier/notify.moe/pages/editor"
"github.com/animenotifier/notify.moe/pages/editor/filteranime" "github.com/animenotifier/notify.moe/pages/editor/filteranime"
"github.com/animenotifier/notify.moe/pages/editor/filtercharacters"
"github.com/animenotifier/notify.moe/pages/editor/filtercompanies" "github.com/animenotifier/notify.moe/pages/editor/filtercompanies"
"github.com/animenotifier/notify.moe/pages/editor/filtersoundtracks" "github.com/animenotifier/notify.moe/pages/editor/filtersoundtracks"
"github.com/animenotifier/notify.moe/pages/editor/jobs" "github.com/animenotifier/notify.moe/pages/editor/jobs"
@ -43,12 +44,16 @@ func Register(app *aero.Application) {
editorFilterable("/editor/anime/details/genres", filteranime.Genres) editorFilterable("/editor/anime/details/genres", filteranime.Genres)
editorFilterable("/editor/anime/details/trailers", filteranime.Trailers) editorFilterable("/editor/anime/details/trailers", filteranime.Trailers)
editorFilterable("/editor/anime/details/startdate", filteranime.StartDate) editorFilterable("/editor/anime/details/startdate", filteranime.StartDate)
editorFilterable("/editor/anime/details/enddate", filteranime.EndDate)
editorFilterable("/editor/anime/details/episodelength", filteranime.EpisodeLength) editorFilterable("/editor/anime/details/episodelength", filteranime.EpisodeLength)
editorFilterable("/editor/anime/details/source", filteranime.Source) editorFilterable("/editor/anime/details/source", filteranime.Source)
editorFilterable("/editor/anime/details/status", filteranime.Status) editorFilterable("/editor/anime/details/status", filteranime.Status)
editorFilterable("/editor/anime/all", filteranime.All) editorFilterable("/editor/anime/all", filteranime.All)
// Editor - Characters
page.Get(app, "/editor/character/image/none", filtercharacters.NoImage)
// Editor - MALdiff // Editor - MALdiff
editorFilterable("/editor/mal/diff/anime", editor.CompareMAL) editorFilterable("/editor/mal/diff/anime", editor.CompareMAL)