diff options
author | Runxi Yu <me@runxiyu.org> | 2025-08-18 03:12:41 +0800 |
---|---|---|
committer | Runxi Yu <me@runxiyu.org> | 2025-08-18 03:12:41 +0800 |
commit | f7dde29539536a67687cbeff9662a9617e077150 (patch) | |
tree | d976eb1f64062a65da4e689bd650ad84be737c52 /forged/internal/incoming/web/handlers/index.go | |
parent | Move sql to inside forged (diff) | |
download | forge-f7dde29539536a67687cbeff9662a9617e077150.tar.gz forge-f7dde29539536a67687cbeff9662a9617e077150.tar.zst forge-f7dde29539536a67687cbeff9662a9617e077150.zip |
Make the index page work
Diffstat (limited to 'forged/internal/incoming/web/handlers/index.go')
-rw-r--r-- | forged/internal/incoming/web/handlers/index.go | 24 |
1 files changed, 19 insertions, 5 deletions
diff --git a/forged/internal/incoming/web/handlers/index.go b/forged/internal/incoming/web/handlers/index.go index 259ca4a..22e6201 100644 --- a/forged/internal/incoming/web/handlers/index.go +++ b/forged/internal/incoming/web/handlers/index.go @@ -4,7 +4,9 @@ import ( "log" "net/http" + "go.lindenii.runxiyu.org/forge/forged/internal/database/queries" "go.lindenii.runxiyu.org/forge/forged/internal/incoming/web/templates" + "go.lindenii.runxiyu.org/forge/forged/internal/incoming/web/types" wtypes "go.lindenii.runxiyu.org/forge/forged/internal/incoming/web/types" ) @@ -12,13 +14,25 @@ type IndexHTTP struct { r templates.Renderer } -func NewIndexHTTP(r templates.Renderer) *IndexHTTP { return &IndexHTTP{r: r} } +func NewIndexHTTP(r templates.Renderer) *IndexHTTP { + return &IndexHTTP{ + r: r, + } +} -func (h *IndexHTTP) Index(w http.ResponseWriter, _ *http.Request, _ wtypes.Vars) { - err := h.r.Render(w, "index", struct { - Title string +func (h *IndexHTTP) Index(w http.ResponseWriter, r *http.Request, _ wtypes.Vars) { + groups, err := types.Base(r).Queries.GetRootGroups(r.Context()) + if err != nil { + http.Error(w, "failed to get root groups", http.StatusInternalServerError) + log.Println("failed to get root groups", "error", err) + return + } + err = h.r.Render(w, "index", struct { + BaseData *types.BaseData + Groups []queries.GetRootGroupsRow }{ - Title: "Home", + BaseData: types.Base(r), + Groups: groups, }) if err != nil { log.Println("failed to render index page", "error", err) |