Refactored single almanach view

This commit is contained in:
Simon Martens
2025-02-25 22:13:02 +01:00
parent 4d65b71563
commit 0a9e71d4e3
11 changed files with 321 additions and 171 deletions

View File

@@ -3,6 +3,7 @@ package pages
import (
"github.com/Theodor-Springmann-Stiftung/musenalm/app"
"github.com/Theodor-Springmann-Stiftung/musenalm/dbmodels"
"github.com/Theodor-Springmann-Stiftung/musenalm/helpers/datatypes"
"github.com/Theodor-Springmann-Stiftung/musenalm/pagemodels"
"github.com/Theodor-Springmann-Stiftung/musenalm/templating"
"github.com/pocketbase/pocketbase/core"
@@ -31,55 +32,12 @@ func (p *AlmanachPage) Setup(router *router.Router[*core.RequestEvent], app core
router.GET(URL_ALMANACH, func(e *core.RequestEvent) error {
id := e.Request.PathValue("id")
data := make(map[string]interface{})
entry, err := dbmodels.EntryForMusenalmID(app, id)
result, err := NewAlmanachResult(app, id)
if err != nil {
return engine.Response404(e, err, data)
}
data["entry"] = entry
series, srelations, _, err := dbmodels.SeriesForEntries(app, []*dbmodels.Entry{entry})
if err != nil {
return engine.Response404(e, err, data)
engine.Response404(e, err, nil)
}
s := map[string]*dbmodels.Series{}
for _, r := range series {
s[r.Id] = r
}
data["srelations"] = srelations
data["series"] = series
places, err := dbmodels.PlacesForEntry(app, entry)
if err != nil {
return engine.Response404(e, err, data)
}
data["places"] = places
contents, err := dbmodels.ContentsForEntry(app, entry)
if err != nil {
return engine.Response404(e, err, data)
}
data["contents"] = contents
agents, arelations, err := dbmodels.AgentsForEntries(app, []*dbmodels.Entry{entry})
if err != nil {
return engine.Response404(e, err, data)
}
data["arelations"] = arelations
if len(contents) > 0 {
cagents, crelations, err := dbmodels.AgentsForContents(app, contents)
if err != nil {
return engine.Response404(e, err, data)
}
data["crelations"] = crelations
for k, v := range cagents {
agents[k] = v
}
}
data["agents"] = agents
data["result"] = result
err = p.getAbbr(app, data)
if err != nil {
return engine.Response404(e, err, data)
@@ -106,11 +64,88 @@ func (p *AlmanachPage) Get(request *core.RequestEvent, engine *templating.Engine
}
type AlmanachResult struct {
Entry *dbmodels.Entry
Places []*dbmodels.Place
Series []*dbmodels.Series
Contents []*dbmodels.Content
Entry *dbmodels.Entry
Places []*dbmodels.Place
Series []*dbmodels.Series
Contents []*dbmodels.Content
Agents map[string]*dbmodels.Agent // <- Key is agent id
EntriesSeries map[string]*dbmodels.REntriesSeries // <- Key is series id
EntriesAgents []*dbmodels.REntriesAgents
ContentsAgents map[string][]*dbmodels.RContentsAgents // <- Key is content id
}
type AlmanachData struct {
func NewAlmanachResult(app core.App, id string) (*AlmanachResult, error) {
// INFO: what about sql.ErrNoRows?
// We don't get sql.ErrNoRows here, since dbx converts every empty slice or
// empty id to a WHERE 0=1 query, which will not error.
entry, err := dbmodels.Entries_MusenalmID(app, id)
if err != nil {
return nil, err
}
places, err := dbmodels.Places_IDs(app, datatypes.ToAny(entry.Places()))
if err != nil {
return nil, err
}
srelations, err := dbmodels.REntriesSeries_Entry(app, entry.Id)
if err != nil {
return nil, err
}
sids := []any{}
srelationsMap := map[string]*dbmodels.REntriesSeries{}
for _, r := range srelations {
sids = append(sids, r.Series())
srelationsMap[r.Series()] = r
}
series, err := dbmodels.Series_IDs(app, sids)
if err != nil {
return nil, err
}
contents, err := dbmodels.Contents_Entry(app, entry.Id)
if err != nil {
return nil, err
}
contentsagents, err := dbmodels.RContentsAgents_Contents(app, dbmodels.Ids(contents))
caids := []any{}
caMap := map[string][]*dbmodels.RContentsAgents{}
for _, r := range contentsagents {
caids = append(caids, r.Agent())
caMap[r.Content()] = append(caMap[r.Content()], r)
}
entriesagents, err := dbmodels.REntriesAgents_Entry(app, entry.Id)
if err != nil {
return nil, err
}
for _, r := range entriesagents {
caids = append(caids, r.Agent())
}
agents, err := dbmodels.Agents_IDs(app, caids)
if err != nil {
return nil, err
}
agentsMap := map[string]*dbmodels.Agent{}
for _, a := range agents {
agentsMap[a.Id] = a
}
return &AlmanachResult{
Entry: entry,
Places: places,
Series: series,
Contents: contents,
Agents: agentsMap,
EntriesSeries: srelationsMap,
EntriesAgents: entriesagents,
ContentsAgents: caMap,
}, nil
}

View File

@@ -65,7 +65,7 @@ type AgentResult struct {
}
func NewAgentResult(app core.App, id string) (*AgentResult, error) {
agent, err := dbmodels.AgentForId(app, id)
agent, err := dbmodels.Agents_ID(app, id)
if err != nil {
return nil, err
}