handle durations for times

This commit is contained in:
Ted Unangst 2019-10-03 00:11:02 -04:00
parent 99f0e73394
commit 3cd2f57f9e
4 changed files with 32 additions and 3 deletions

View File

@ -717,6 +717,12 @@ func xonksaver(user *WhatAbout, item junk.Junk, origin string) *Honk {
if err == nil { if err == nil {
t := new(Time) t := new(Time)
t.StartTime = start t.StartTime = start
dura, _ := obj.GetString("duration")
if strings.HasPrefix(dura, "PT") {
dura = strings.ToLower(dura[2:])
d, _ := time.ParseDuration(dura)
t.Duration = Duration(d)
}
xonk.Time = t xonk.Time = t
} }
} }
@ -1002,6 +1008,9 @@ func jonkjonk(user *WhatAbout, h *Honk) (junk.Junk, junk.Junk) {
} }
if t := h.Time; t != nil { if t := h.Time; t != nil {
jo["startTime"] = t.StartTime.Format(time.RFC3339) jo["startTime"] = t.StartTime.Format(time.RFC3339)
if t.Duration != 0 {
jo["duration"] = "PT" + strings.ToUpper(t.Duration.String())
}
} }
var atts []junk.Junk var atts []junk.Junk
for _, d := range h.Donks { for _, d := range h.Donks {

16
honk.go
View File

@ -20,6 +20,7 @@ import (
"html/template" "html/template"
"log" "log"
"os" "os"
"strings"
"time" "time"
) )
@ -101,10 +102,23 @@ type Place struct {
Url string Url string
} }
type Duration int64
func (d Duration) String() string {
s := time.Duration(d).String()
if strings.HasSuffix(s, "m0s") {
s = s[:len(s)-2]
}
if strings.HasSuffix(s, "h0m") {
s = s[:len(s)-2]
}
return s
}
type Time struct { type Time struct {
StartTime time.Time StartTime time.Time
EndTime time.Time EndTime time.Time
Duration time.Duration Duration Duration
} }
type Honker struct { type Honker struct {

View File

@ -44,6 +44,7 @@ in reply to: <a href="{{ .RID }}" rel=noreferrer>{{ .RID }}</a>
<p>{{ .HTML }} <p>{{ .HTML }}
{{ with .Time }} {{ with .Time }}
<p>Time: {{ .StartTime.Local.Format "03:04PM EDT Mon Jan 02"}} <p>Time: {{ .StartTime.Local.Format "03:04PM EDT Mon Jan 02"}}
{{ if .Duration }}<br>Duration: {{ .Duration }}{{ end }}
{{ end }} {{ end }}
{{ with .Place }} {{ with .Place }}
<p>Location: {{ with .Url }}<a href="{{ . }}" rel=noreferrer>{{ end }}{{ .Name }}{{ if .Url }}</a>{{ end }}{{ if or .Latitude .Longitude }} <a href="https://www.openstreetmap.org/?mlat={{ .Latitude }}&mlon={{ .Longitude}}" rel=noreferrer>{{ .Latitude }} {{ .Longitude }}</a>{{ end }} <p>Location: {{ with .Url }}<a href="{{ . }}" rel=noreferrer>{{ end }}{{ .Name }}{{ if .Url }}</a>{{ end }}{{ if or .Latitude .Longitude }} <a href="https://www.openstreetmap.org/?mlat={{ .Latitude }}&mlon={{ .Longitude}}" rel=noreferrer>{{ .Latitude }} {{ .Longitude }}</a>{{ end }}

9
web.go
View File

@ -1054,8 +1054,8 @@ func submithonk(w http.ResponseWriter, r *http.Request) {
if timestart != "" { if timestart != "" {
t := new(Time) t := new(Time)
now := time.Now().Local() now := time.Now().Local()
for _, layout := range []string{"3:04pm", "15:04"} { for _, layout := range []string{"2006-01-02 3:04pm", "2006-01-02 15:04", "3:04pm", "15:04"} {
start, err := time.Parse(layout, timestart) start, err := time.ParseInLocation(layout, timestart, now.Location())
if err == nil { if err == nil {
if start.Year() == 0 { if start.Year() == 0 {
start = time.Date(now.Year(), now.Month(), now.Day(), start.Hour(), start.Minute(), 0, 0, now.Location()) start = time.Date(now.Year(), now.Month(), now.Day(), start.Hour(), start.Minute(), 0, 0, now.Location())
@ -1064,6 +1064,11 @@ func submithonk(w http.ResponseWriter, r *http.Request) {
break break
} }
} }
timeend := r.FormValue("timeend")
dur, err := time.ParseDuration(timeend)
if err == nil {
t.Duration = Duration(dur)
}
if !t.StartTime.IsZero() { if !t.StartTime.IsZero() {
honk.What = "event" honk.What = "event"
honk.Time = t honk.Time = t