again verbose

main
bel 2024-04-13 23:16:20 -06:00
parent 8a67f505ce
commit e8d52274e7
2 changed files with 39 additions and 30 deletions

View File

@ -58,17 +58,33 @@ func ReportSince(ctx context.Context, w io.Writer, s Storage, t time.Time) error
return err
}
events, err := s.EventsSince(ctx, t)
eventIDs, err := s.EventsSince(ctx, t)
if err != nil {
return err
}
type aThread struct {
Thread string
Messages []Message
First Message
Last Message
}
type anEvent struct {
Event string
Threads []aThread
First Message
Last Message
}
type someEvents struct {
Events []anEvent
}
return tmpl.Execute(w, map[string]any{
"since": t.Format("2006-01-02"),
"events": func() any {
threads := make([]any, len(events))
for i, event := range events {
threads[i] = func() any {
"events": func() someEvents {
events := make([]anEvent, len(eventIDs))
for i, event := range eventIDs {
events[i] = func() anEvent {
threadNames := []string{}
for _, m := range messages {
if m.Event == event {
@ -77,9 +93,9 @@ func ReportSince(ctx context.Context, w io.Writer, s Storage, t time.Time) error
}
slices.Sort(threadNames)
slices.Compact(threadNames)
threads := make([]any, len(threadNames))
threads := make([]aThread, len(threadNames))
for i, thread := range threadNames {
threads[i] = func() any {
threads[i] = func() aThread {
messages := []Message{}
for _, m := range messages {
if m.Thread == thread {
@ -89,16 +105,16 @@ func ReportSince(ctx context.Context, w io.Writer, s Storage, t time.Time) error
sort.Slice(messages, func(i, j int) bool {
return messages[i].TS < messages[j].TS
})
return map[string]any{
"thread": thread,
"messages": messages,
"first": func() any {
return aThread{
Thread: thread,
Messages: messages,
First: func() Message {
if len(messages) == 0 {
return Message{}
}
return messages[0]
}(),
"last": func() any {
Last: func() Message {
if len(messages) == 0 {
return Message{}
}
@ -108,28 +124,28 @@ func ReportSince(ctx context.Context, w io.Writer, s Storage, t time.Time) error
}()
}
sort.Slice(threads, func(i, j int) bool {
return threads[i].(map[string]any)["first"].(Message).TS < threads[j].(map[string]any)["first"].(Message).TS
return threads[i].First.TS < threads[j].First.TS
})
return map[string]any{
"event": event,
"threads": threads,
"first": func() any {
return anEvent{
Event: event,
Threads: threads,
First: func() Message {
if len(threads) == 0 {
return Message{}
}
return threads[0].(map[string]any)["first"]
return threads[0].First
}(),
"last": func() any {
Last: func() Message {
if len(threads) == 0 {
return Message{}
}
return threads[len(threads)-1].(map[string]any)["last"]
return threads[len(threads)-1].Last
}(),
}
}()
}
return map[string]any{
"threads": threads,
return someEvents{
Events: events,
}
}(),
"messages": messages,

View File

@ -60,15 +60,8 @@
<th>Source</th>
</tr>
{{ range .events }}
{{ $first_ts := 0 }}
{{ $event := "" }}
{{ $event_name := "" }}
{{ $last_plaintext := "" }}
{{ $source := "" }}
{{ range . }}
{{ end }}
<tr>
<td>{{ time "Unix" $first_ts | time "Time.Format" "Mon Jan 02" }}</td>
<td>{{ time "Unix" .threads.first.TS | time "Time.Format" "Mon Jan 02" }}</td>
</tr>
{{ end }}
</table>