hmn/src/website/jam.go

344 lines
12 KiB
Go
Raw Normal View History

2021-08-28 11:26:17 +00:00
package website
import (
2021-09-25 03:53:00 +00:00
"net/http"
"time"
"git.handmade.network/hmn/hmn/src/hmndata"
2021-08-28 11:26:17 +00:00
"git.handmade.network/hmn/hmn/src/hmnurl"
2021-09-25 03:53:00 +00:00
"git.handmade.network/hmn/hmn/src/oops"
2021-08-28 11:26:17 +00:00
"git.handmade.network/hmn/hmn/src/templates"
2022-06-17 22:30:18 +00:00
"git.handmade.network/hmn/hmn/src/utils"
2021-08-28 11:26:17 +00:00
)
2023-03-07 17:37:01 +00:00
func JamIndex2023_Visibility(c *RequestContext) ResponseData {
var res ResponseData
daysUntilStart := daysUntil(hmndata.VJ2023.StartTime)
daysUntilEnd := daysUntil(hmndata.VJ2023.EndTime)
baseData := getBaseDataAutocrumb(c, hmndata.VJ2023.Name)
baseData.OpenGraphItems = []templates.OpenGraphItem{
2023-03-07 17:57:44 +00:00
{Property: "og:title", Value: "Visibility Jam"},
{Property: "og:site_name", Value: "Handmade Network"},
2023-03-07 17:37:01 +00:00
{Property: "og:type", Value: "website"},
{Property: "og:image", Value: hmnurl.BuildPublic("visjam2023/opengraph.png", true)},
{Property: "og:description", Value: "See things in a new way. April 14 - 16."},
{Property: "og:url", Value: hmnurl.BuildJamIndex()},
2023-03-07 18:07:02 +00:00
{Name: "twitter:card", Value: "summary_large_image"},
{Name: "twitter:image", Value: hmnurl.BuildPublic("visjam2023/TwitterCard.png", true)},
2023-03-07 17:37:01 +00:00
}
type JamPageData struct {
templates.BaseData
DaysUntilStart, DaysUntilEnd int
StartTimeUnix, EndTimeUnix int64
SubmittedProjectUrl string
ProjectSubmissionUrl string
ShowcaseFeedUrl string
ShowcaseJson string
JamProjects []templates.Project
}
var showcaseItems []templates.TimelineItem
submittedProjectUrl := ""
if c.CurrentUser != nil {
projects, err := hmndata.FetchProjects(c, c.Conn, c.CurrentUser, hmndata.ProjectsQuery{
OwnerIDs: []int{c.CurrentUser.ID},
JamSlugs: []string{hmndata.VJ2023.Slug},
Limit: 1,
})
if err != nil {
return c.ErrorResponse(http.StatusInternalServerError, oops.New(err, "failed to fetch jam projects for current user"))
}
if len(projects) > 0 {
urlContext := hmndata.UrlContextForProject(&projects[0].Project)
submittedProjectUrl = urlContext.BuildHomepage()
}
}
jamProjects, err := hmndata.FetchProjects(c, c.Conn, c.CurrentUser, hmndata.ProjectsQuery{
JamSlugs: []string{hmndata.VJ2023.Slug},
})
if err != nil {
return c.ErrorResponse(http.StatusInternalServerError, oops.New(err, "failed to fetch jam projects for current user"))
}
pageProjects := make([]templates.Project, 0, len(jamProjects))
for _, p := range jamProjects {
pageProjects = append(pageProjects, templates.ProjectAndStuffToTemplate(&p, hmndata.UrlContextForProject(&p.Project).BuildHomepage(), c.Theme))
}
projectIds := make([]int, 0, len(jamProjects))
for _, jp := range jamProjects {
projectIds = append(projectIds, jp.Project.ID)
}
if len(projectIds) > 0 {
snippets, err := hmndata.FetchSnippets(c, c.Conn, c.CurrentUser, hmndata.SnippetQuery{
ProjectIDs: projectIds,
Limit: 12,
})
if err != nil {
return c.ErrorResponse(http.StatusInternalServerError, oops.New(err, "failed to fetch snippets for jam showcase"))
}
showcaseItems = make([]templates.TimelineItem, 0, len(snippets))
for _, s := range snippets {
timelineItem := SnippetToTimelineItem(&s.Snippet, s.Asset, s.DiscordMessage, s.Projects, s.Owner, c.Theme, false)
if timelineItem.CanShowcase {
showcaseItems = append(showcaseItems, timelineItem)
}
}
}
showcaseJson := templates.TimelineItemsToJSON(showcaseItems)
res.MustWriteTemplate("jam_2023_visibility.html", JamPageData{
BaseData: baseData,
DaysUntilStart: daysUntilStart,
DaysUntilEnd: daysUntilEnd,
StartTimeUnix: hmndata.VJ2023.StartTime.Unix(),
EndTimeUnix: hmndata.VJ2023.EndTime.Unix(),
ProjectSubmissionUrl: hmnurl.BuildProjectNewJam(),
SubmittedProjectUrl: submittedProjectUrl,
ShowcaseFeedUrl: hmnurl.BuildJamFeed2022(),
ShowcaseJson: showcaseJson,
JamProjects: pageProjects,
}, c.Perf)
return res
}
2022-06-17 22:30:18 +00:00
func JamIndex2022(c *RequestContext) ResponseData {
var res ResponseData
2022-06-19 22:26:33 +00:00
daysUntilStart := daysUntil(hmndata.WRJ2022.StartTime)
daysUntilEnd := daysUntil(hmndata.WRJ2022.EndTime)
baseData := getBaseDataAutocrumb(c, hmndata.WRJ2022.Name)
2022-06-17 22:30:18 +00:00
baseData.OpenGraphItems = []templates.OpenGraphItem{
2023-03-07 17:57:44 +00:00
{Property: "og:site_name", Value: "Handmade Network"},
2022-06-17 22:30:18 +00:00
{Property: "og:type", Value: "website"},
{Property: "og:image", Value: hmnurl.BuildPublic("wheeljam2022/opengraph.png", true)},
{Property: "og:description", Value: "A one-week jam to change the status quo. August 15 - 21 on Handmade Network."},
2022-06-17 22:30:18 +00:00
{Property: "og:url", Value: hmnurl.BuildJamIndex()},
}
type JamPageData struct {
templates.BaseData
DaysUntilStart, DaysUntilEnd int
2022-08-05 02:00:15 +00:00
StartTimeUnix, EndTimeUnix int64
2022-08-07 01:21:12 +00:00
SubmittedProjectUrl string
ProjectSubmissionUrl string
ShowcaseFeedUrl string
ShowcaseJson string
JamProjects []templates.Project
2022-06-17 22:30:18 +00:00
}
2022-06-25 13:24:04 +00:00
var showcaseItems []templates.TimelineItem
submittedProjectUrl := ""
2022-08-07 01:21:12 +00:00
if c.CurrentUser != nil {
projects, err := hmndata.FetchProjects(c, c.Conn, c.CurrentUser, hmndata.ProjectsQuery{
OwnerIDs: []int{c.CurrentUser.ID},
2022-06-25 13:24:04 +00:00
JamSlugs: []string{hmndata.WRJ2022.Slug},
2022-08-07 01:21:12 +00:00
Limit: 1,
2022-06-25 13:24:04 +00:00
})
if err != nil {
return c.ErrorResponse(http.StatusInternalServerError, oops.New(err, "failed to fetch jam projects for current user"))
}
2022-08-07 01:21:12 +00:00
if len(projects) > 0 {
urlContext := hmndata.UrlContextForProject(&projects[0].Project)
submittedProjectUrl = urlContext.BuildHomepage()
2022-06-25 13:24:04 +00:00
}
2022-08-07 01:21:12 +00:00
}
2022-06-25 13:24:04 +00:00
2022-08-07 01:21:12 +00:00
jamProjects, err := hmndata.FetchProjects(c, c.Conn, c.CurrentUser, hmndata.ProjectsQuery{
JamSlugs: []string{hmndata.WRJ2022.Slug},
})
if err != nil {
return c.ErrorResponse(http.StatusInternalServerError, oops.New(err, "failed to fetch jam projects for current user"))
}
pageProjects := make([]templates.Project, 0, len(jamProjects))
for _, p := range jamProjects {
pageProjects = append(pageProjects, templates.ProjectAndStuffToTemplate(&p, hmndata.UrlContextForProject(&p.Project).BuildHomepage(), c.Theme))
}
projectIds := make([]int, 0, len(jamProjects))
for _, jp := range jamProjects {
projectIds = append(projectIds, jp.Project.ID)
}
if len(projectIds) > 0 {
snippets, err := hmndata.FetchSnippets(c, c.Conn, c.CurrentUser, hmndata.SnippetQuery{
ProjectIDs: projectIds,
Limit: 12,
})
if err != nil {
return c.ErrorResponse(http.StatusInternalServerError, oops.New(err, "failed to fetch snippets for jam showcase"))
}
showcaseItems = make([]templates.TimelineItem, 0, len(snippets))
for _, s := range snippets {
timelineItem := SnippetToTimelineItem(&s.Snippet, s.Asset, s.DiscordMessage, s.Projects, s.Owner, c.Theme, false)
if timelineItem.CanShowcase {
showcaseItems = append(showcaseItems, timelineItem)
2022-06-25 13:24:04 +00:00
}
}
}
2022-08-07 01:21:12 +00:00
2022-06-25 13:24:04 +00:00
showcaseJson := templates.TimelineItemsToJSON(showcaseItems)
2023-03-07 17:37:01 +00:00
res.MustWriteTemplate("jam_2022_wrj_index.html", JamPageData{
2022-06-25 13:24:04 +00:00
BaseData: baseData,
DaysUntilStart: daysUntilStart,
DaysUntilEnd: daysUntilEnd,
2022-08-05 02:00:15 +00:00
StartTimeUnix: hmndata.WRJ2022.StartTime.Unix(),
EndTimeUnix: hmndata.WRJ2022.EndTime.Unix(),
2022-06-25 13:24:04 +00:00
ProjectSubmissionUrl: hmnurl.BuildProjectNewJam(),
SubmittedProjectUrl: submittedProjectUrl,
ShowcaseFeedUrl: hmnurl.BuildJamFeed2022(),
ShowcaseJson: showcaseJson,
2022-08-07 01:21:12 +00:00
JamProjects: pageProjects,
2022-06-17 22:30:18 +00:00
}, c.Perf)
return res
}
2022-06-19 22:26:33 +00:00
func JamFeed2022(c *RequestContext) ResponseData {
jamProjects, err := hmndata.FetchProjects(c, c.Conn, c.CurrentUser, hmndata.ProjectsQuery{
2022-06-25 13:24:04 +00:00
JamSlugs: []string{hmndata.WRJ2022.Slug},
})
if err != nil {
return c.ErrorResponse(http.StatusInternalServerError, oops.New(err, "failed to fetch jam projects for current user"))
}
2022-08-05 04:20:11 +00:00
projectIds := make([]int, 0, len(jamProjects))
2022-06-25 13:24:04 +00:00
for _, jp := range jamProjects {
2022-08-05 04:20:11 +00:00
projectIds = append(projectIds, jp.Project.ID)
2022-06-25 13:24:04 +00:00
}
2022-08-06 02:19:49 +00:00
var timelineItems []templates.TimelineItem
if len(projectIds) > 0 {
snippets, err := hmndata.FetchSnippets(c, c.Conn, c.CurrentUser, hmndata.SnippetQuery{
ProjectIDs: projectIds,
})
if err != nil {
return c.ErrorResponse(http.StatusInternalServerError, oops.New(err, "failed to fetch snippets for jam showcase"))
}
2022-06-25 13:24:04 +00:00
2022-08-06 02:19:49 +00:00
timelineItems = make([]templates.TimelineItem, 0, len(snippets))
for _, s := range snippets {
timelineItem := SnippetToTimelineItem(&s.Snippet, s.Asset, s.DiscordMessage, s.Projects, s.Owner, c.Theme, false)
timelineItem.SmallInfo = true
timelineItems = append(timelineItems, timelineItem)
}
2022-06-25 13:24:04 +00:00
}
pageProjects := make([]templates.Project, 0, len(jamProjects))
for _, p := range jamProjects {
pageProjects = append(pageProjects, templates.ProjectAndStuffToTemplate(&p, hmndata.UrlContextForProject(&p.Project).BuildHomepage(), c.Theme))
}
type JamFeedData struct {
templates.BaseData
2022-08-05 04:22:30 +00:00
DaysUntilStart, DaysUntilEnd int
2022-06-25 13:24:04 +00:00
JamProjects []templates.Project
TimelineItems []templates.TimelineItem
}
2022-08-05 04:22:30 +00:00
daysUntilStart := daysUntil(hmndata.WRJ2022.StartTime)
daysUntilEnd := daysUntil(hmndata.WRJ2022.EndTime)
2022-06-25 13:24:04 +00:00
baseData := getBaseDataAutocrumb(c, hmndata.WRJ2022.Name)
baseData.OpenGraphItems = []templates.OpenGraphItem{
2023-03-07 17:57:44 +00:00
{Property: "og:site_name", Value: "Handmade Network"},
2022-06-25 13:24:04 +00:00
{Property: "og:type", Value: "website"},
{Property: "og:image", Value: hmnurl.BuildPublic("wheeljam2022/opengraph.png", true)},
{Property: "og:description", Value: "A one-week jam to change the status quo. August 15 - 21 on Handmade Network."},
{Property: "og:url", Value: hmnurl.BuildJamIndex()},
}
var res ResponseData
2023-03-07 17:37:01 +00:00
res.MustWriteTemplate("jam_2022_wrj_feed.html", JamFeedData{
2022-08-05 04:22:30 +00:00
BaseData: baseData,
DaysUntilStart: daysUntilStart,
DaysUntilEnd: daysUntilEnd,
JamProjects: pageProjects,
TimelineItems: timelineItems,
2022-06-25 13:24:04 +00:00
}, c.Perf)
return res
2022-06-19 22:26:33 +00:00
}
2022-06-17 22:30:18 +00:00
func JamIndex2021(c *RequestContext) ResponseData {
2021-08-28 11:26:17 +00:00
var res ResponseData
2022-06-19 22:26:33 +00:00
daysUntilJam := daysUntil(hmndata.WRJ2021.StartTime)
2022-06-17 22:30:18 +00:00
if daysUntilJam < 0 {
daysUntilJam = 0
}
2021-08-28 11:26:17 +00:00
tagId := -1
jamTag, err := hmndata.FetchTag(c, c.Conn, hmndata.TagQuery{
Text: []string{"wheeljam"},
})
2021-11-11 19:00:46 +00:00
if err == nil {
tagId = jamTag.ID
2021-11-11 19:00:46 +00:00
} else {
c.Logger.Warn().Err(err).Msg("failed to fetch jam tag; will fetch all snippets as a result")
2021-09-25 03:53:00 +00:00
}
2021-11-11 19:00:46 +00:00
snippets, err := hmndata.FetchSnippets(c, c.Conn, c.CurrentUser, hmndata.SnippetQuery{
Tags: []int{tagId},
2021-11-11 19:00:46 +00:00
})
2021-09-25 03:53:00 +00:00
if err != nil {
return c.ErrorResponse(http.StatusInternalServerError, oops.New(err, "failed to fetch jam snippets"))
}
2021-11-11 19:00:46 +00:00
showcaseItems := make([]templates.TimelineItem, 0, len(snippets))
for _, s := range snippets {
2022-08-05 04:03:45 +00:00
timelineItem := SnippetToTimelineItem(&s.Snippet, s.Asset, s.DiscordMessage, s.Projects, s.Owner, c.Theme, false)
if timelineItem.CanShowcase {
2021-09-25 03:53:00 +00:00
showcaseItems = append(showcaseItems, timelineItem)
}
}
c.Perf.EndBlock()
c.Perf.StartBlock("SHOWCASE", "Convert to json")
showcaseJson := templates.TimelineItemsToJSON(showcaseItems)
c.Perf.EndBlock()
2022-06-19 22:26:33 +00:00
baseData := getBaseDataAutocrumb(c, hmndata.WRJ2021.Name)
2021-08-28 11:26:17 +00:00
baseData.OpenGraphItems = []templates.OpenGraphItem{
2023-03-07 17:57:44 +00:00
{Property: "og:site_name", Value: "Handmade Network"},
2021-08-28 11:26:17 +00:00
{Property: "og:type", Value: "website"},
{Property: "og:image", Value: hmnurl.BuildPublic("wheeljam2021/opengraph.png", true)},
2021-08-28 11:26:17 +00:00
{Property: "og:description", Value: "A one-week jam to bring a fresh perspective to old ideas. September 27 - October 3 on Handmade Network."},
{Property: "og:url", Value: hmnurl.BuildJamIndex()},
}
type JamPageData struct {
templates.BaseData
2021-09-25 03:53:00 +00:00
DaysUntil int
ShowcaseItemsJSON string
}
2023-03-07 17:37:01 +00:00
res.MustWriteTemplate("jam_2021_wrj_index.html", JamPageData{
2021-09-25 03:53:00 +00:00
BaseData: baseData,
2022-06-17 22:30:18 +00:00
DaysUntil: daysUntilJam,
2021-09-25 03:53:00 +00:00
ShowcaseItemsJSON: showcaseJson,
}, c.Perf)
2021-08-28 11:26:17 +00:00
return res
}
2022-06-17 22:30:18 +00:00
func daysUntil(t time.Time) int {
d := t.Sub(time.Now())
if d < 0 {
d = 0
}
return int(utils.DurationRoundUp(d, 24*time.Hour) / (24 * time.Hour))
}