1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
|
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Agent Context - {{.AgentName}}</title>
<style>
body { font-family: system-ui, sans-serif; max-width: 800px; margin: 40px auto; padding: 20px; background: #1a1a2e; color: #eee; }
.card { background: #16213e; border-radius: 8px; padding: 24px; margin-bottom: 20px; }
h1 { color: #e94560; margin-top: 0; }
h2 { color: #0f3460; font-size: 1.2em; margin-top: 24px; }
.label { color: #888; font-size: 0.9em; margin-bottom: 4px; }
.value { font-family: monospace; background: #0f0f23; padding: 8px 12px; border-radius: 4px; word-break: break-all; margin-bottom: 16px; }
.summary { display: grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: 12px; margin-bottom: 20px; }
.summary-item { background: #0f3460; padding: 12px; border-radius: 6px; text-align: center; }
.summary-value { font-size: 1.5em; font-weight: bold; color: #e94560; }
.summary-label { font-size: 0.8em; color: #888; }
table { width: 100%; border-collapse: collapse; margin-top: 16px; }
th, td { padding: 10px; text-align: left; border-bottom: 1px solid #333; }
th { background: #0f3460; color: #fff; }
tr:hover { background: #1a1a2e; }
.source { display: inline-block; padding: 2px 8px; border-radius: 10px; font-size: 0.8em; }
.source-todoist { background: #e44332; color: #fff; }
.source-trello { background: #0079bf; color: #fff; }
.source-plantoeat { background: #5cb85c; color: #fff; }
.due-overdue { color: #dc3545; }
.due-today { color: #ffc107; }
.due-future { color: #28a745; }
a { color: #4da6ff; }
</style>
</head>
<body>
<script type="application/json" id="agent-data">
{
"generated_at": "{{.GeneratedAt}}",
"range": {
"start": "{{.RangeStart}}",
"end": "{{.RangeEnd}}"
},
"summary": {
"total_items": {{with .Summary}}{{.total_items}}{{else}}0{{end}},
"overdue": {{with .Summary}}{{.overdue}}{{else}}0{{end}},
"today": {{with .Summary}}{{.today}}{{else}}0{{end}}
},
"timeline": [{{range $i, $item := .Timeline}}{{if $i}},{{end}}
{
"id": "{{$item.ID}}",
"source": "{{$item.Source}}",
"type": "{{$item.Type}}",
"title": "{{$item.Title}}",
"description": "{{$item.Description}}",
"due": {{if $item.Due}}"{{$item.Due.Format "2006-01-02T15:04:05Z07:00"}}"{{else}}null{{end}},
"priority": {{$item.Priority}},
"completable": {{$item.Completable}},
"url": "{{$item.URL}}"
}{{end}}
]
}
</script>
<div class="card">
<h1>Agent Context</h1>
<p>Timeline data for <strong>{{.AgentName}}</strong></p>
<div class="label">Generated At</div>
<div class="value">{{.GeneratedAt}}</div>
<div class="label">Date Range</div>
<div class="value">{{.RangeStart}} to {{.RangeEnd}}</div>
</div>
<div class="card">
<h2>Summary</h2>
<div class="summary">
<div class="summary-item">
<div class="summary-value">{{with .Summary}}{{.total_items}}{{else}}0{{end}}</div>
<div class="summary-label">Total Items</div>
</div>
<div class="summary-item">
<div class="summary-value">{{with .Summary}}{{.overdue}}{{else}}0{{end}}</div>
<div class="summary-label">Overdue</div>
</div>
<div class="summary-item">
<div class="summary-value">{{with .Summary}}{{.today}}{{else}}0{{end}}</div>
<div class="summary-label">Due Today</div>
</div>
</div>
</div>
<div class="card">
<h2>Timeline</h2>
{{if .Timeline}}
<table>
<thead>
<tr>
<th>Source</th>
<th>Title</th>
<th>Due</th>
<th>Type</th>
</tr>
</thead>
<tbody>
{{range .Timeline}}
<tr>
<td><span class="source source-{{.Source}}">{{.Source}}</span></td>
<td>
{{if .URL}}<a href="{{.URL}}" target="_blank">{{.Title}}</a>{{else}}{{.Title}}{{end}}
{{if .Description}}<br><small style="color: #888;">{{.Description}}</small>{{end}}
</td>
<td>{{if .Due}}{{.Due.Format "Jan 2, 3:04 PM"}}{{else}}-{{end}}</td>
<td>{{.Type}}</td>
</tr>
{{end}}
</tbody>
</table>
{{else}}
<p>No items in the timeline for this date range.</p>
{{end}}
</div>
</body>
</html>
|