mirror of
https://github.com/Freika/dawarich.git
synced 2026-01-10 17:21:38 -05:00
254 lines
6.8 KiB
Text
254 lines
6.8 KiB
Text
<!DOCTYPE html>
|
|
<html>
|
|
<head>
|
|
<meta charset="utf-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
<style>
|
|
body {
|
|
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
|
|
line-height: 1.6;
|
|
color: #333;
|
|
max-width: 600px;
|
|
margin: 0 auto;
|
|
padding: 0;
|
|
background-color: #f5f5f5;
|
|
}
|
|
.header {
|
|
background: linear-gradient(135deg, #2563eb, #7c3aed);
|
|
color: white;
|
|
padding: 40px 30px;
|
|
text-align: center;
|
|
border-radius: 8px 8px 0 0;
|
|
}
|
|
.header h1 {
|
|
margin: 0 0 10px 0;
|
|
font-size: 28px;
|
|
font-weight: 700;
|
|
}
|
|
.header p {
|
|
margin: 0;
|
|
opacity: 0.9;
|
|
font-size: 16px;
|
|
}
|
|
.content {
|
|
padding: 30px;
|
|
background: #ffffff;
|
|
}
|
|
.stat-card {
|
|
background: #f8fafc;
|
|
border-radius: 12px;
|
|
padding: 20px;
|
|
margin: 16px 0;
|
|
border: 1px solid #e2e8f0;
|
|
}
|
|
.stat-value {
|
|
font-size: 36px;
|
|
font-weight: 700;
|
|
color: #2563eb;
|
|
margin: 0;
|
|
}
|
|
.stat-label {
|
|
color: #64748b;
|
|
font-size: 14px;
|
|
text-transform: uppercase;
|
|
letter-spacing: 0.5px;
|
|
margin-bottom: 8px;
|
|
}
|
|
.stat-description {
|
|
color: #475569;
|
|
font-size: 14px;
|
|
margin-top: 8px;
|
|
}
|
|
.first-time-badge {
|
|
display: inline-block;
|
|
background: #10b981;
|
|
color: white;
|
|
padding: 3px 10px;
|
|
border-radius: 12px;
|
|
font-size: 11px;
|
|
font-weight: 600;
|
|
text-transform: uppercase;
|
|
margin-right: 8px;
|
|
}
|
|
.comparison {
|
|
font-weight: 600;
|
|
font-size: 14px;
|
|
}
|
|
.comparison.positive {
|
|
color: #10b981;
|
|
}
|
|
.comparison.negative {
|
|
color: #ef4444;
|
|
}
|
|
.chart-container {
|
|
background: #f8fafc;
|
|
border-radius: 12px;
|
|
padding: 20px;
|
|
margin: 20px 0;
|
|
text-align: center;
|
|
border: 1px solid #e2e8f0;
|
|
}
|
|
.chart-container img {
|
|
max-width: 100%;
|
|
height: auto;
|
|
border-radius: 8px;
|
|
}
|
|
.location-list {
|
|
margin: 10px 0;
|
|
padding: 0;
|
|
list-style: none;
|
|
}
|
|
.location-list li {
|
|
padding: 8px 0;
|
|
border-bottom: 1px solid #e2e8f0;
|
|
display: flex;
|
|
justify-content: space-between;
|
|
}
|
|
.location-list li:last-child {
|
|
border-bottom: none;
|
|
}
|
|
.all-time-footer {
|
|
background: #1e293b;
|
|
color: white;
|
|
border-radius: 12px;
|
|
padding: 24px;
|
|
margin: 20px 0;
|
|
}
|
|
.all-time-footer h3 {
|
|
color: white;
|
|
margin: 0 0 16px 0;
|
|
font-size: 18px;
|
|
}
|
|
.all-time-stat {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
padding: 8px 0;
|
|
border-bottom: 1px solid rgba(255,255,255,0.1);
|
|
}
|
|
.all-time-stat:last-child {
|
|
border-bottom: none;
|
|
}
|
|
.all-time-stat .label {
|
|
opacity: 0.8;
|
|
}
|
|
.all-time-stat .value {
|
|
font-weight: 600;
|
|
}
|
|
.footer {
|
|
text-align: center;
|
|
padding: 30px;
|
|
color: #64748b;
|
|
font-size: 12px;
|
|
background: #ffffff;
|
|
border-radius: 0 0 8px 8px;
|
|
}
|
|
.footer a {
|
|
color: #2563eb;
|
|
text-decoration: none;
|
|
}
|
|
.unsubscribe {
|
|
color: #94a3b8;
|
|
font-size: 11px;
|
|
margin-top: 16px;
|
|
}
|
|
.unsubscribe a {
|
|
color: #94a3b8;
|
|
}
|
|
</style>
|
|
</head>
|
|
<body>
|
|
<div class="header">
|
|
<h1><%= @digest.year %> Year in Review</h1>
|
|
<p>Your journey, by the numbers</p>
|
|
</div>
|
|
|
|
<div class="content">
|
|
<!-- Distance Traveled -->
|
|
<div class="stat-card">
|
|
<div class="stat-label">Distance Traveled</div>
|
|
<p class="stat-value"><%= distance_with_unit(@digest.distance, @distance_unit) %></p>
|
|
<p class="stat-description"><%= distance_comparison_text(@digest.distance) %></p>
|
|
<% if @digest.yoy_distance_change %>
|
|
<p class="comparison <%= yoy_change_class(@digest.yoy_distance_change) %>">
|
|
<%= yoy_change_text(@digest.yoy_distance_change) %> compared to <%= @digest.previous_year %>
|
|
</p>
|
|
<% end %>
|
|
</div>
|
|
|
|
<!-- Countries Visited -->
|
|
<div class="stat-card">
|
|
<div class="stat-label">Countries Visited</div>
|
|
<p class="stat-value"><%= @digest.countries_count %></p>
|
|
<% if @digest.first_time_countries.any? %>
|
|
<p class="stat-description">
|
|
<span class="first-time-badge">New</span>
|
|
First time in: <%= @digest.first_time_countries.join(', ') %>
|
|
</p>
|
|
<% end %>
|
|
</div>
|
|
|
|
<!-- Cities Visited -->
|
|
<div class="stat-card">
|
|
<div class="stat-label">Cities Explored</div>
|
|
<p class="stat-value"><%= @digest.cities_count %></p>
|
|
<% if @digest.first_time_cities.any? %>
|
|
<p class="stat-description">
|
|
<span class="first-time-badge">New</span>
|
|
<% cities_to_show = @digest.first_time_cities.take(5) %>
|
|
First time in: <%= cities_to_show.join(', ') %>
|
|
<% if @digest.first_time_cities.count > 5 %>
|
|
and <%= @digest.first_time_cities.count - 5 %> more
|
|
<% end %>
|
|
</p>
|
|
<% end %>
|
|
</div>
|
|
|
|
<!-- Monthly Distance Chart -->
|
|
<% if @chart_image_name %>
|
|
<div class="chart-container">
|
|
<h3 style="margin: 0 0 16px 0; color: #1e293b;">Your Year, Month by Month</h3>
|
|
<%= image_tag attachments[@chart_image_name].url, alt: 'Monthly Distance Chart' %>
|
|
</div>
|
|
<% end %>
|
|
|
|
<!-- Top Locations by Time Spent -->
|
|
<% if @digest.top_countries_by_time.any? %>
|
|
<div class="stat-card">
|
|
<div class="stat-label">Where You Spent the Most Time</div>
|
|
<ul class="location-list">
|
|
<% @digest.top_countries_by_time.take(3).each do |country| %>
|
|
<li>
|
|
<span><%= country['name'] %></span>
|
|
<span><%= format_time_spent(country['minutes']) %></span>
|
|
</li>
|
|
<% end %>
|
|
</ul>
|
|
</div>
|
|
<% end %>
|
|
|
|
<!-- All-Time Stats Footer -->
|
|
<div class="all-time-footer">
|
|
<h3>All-Time Stats</h3>
|
|
<div class="all-time-stat">
|
|
<span class="label">Countries visited</span>
|
|
<span class="value"><%= @digest.total_countries_all_time %></span>
|
|
</div>
|
|
<div class="all-time-stat">
|
|
<span class="label">Cities explored</span>
|
|
<span class="value"><%= @digest.total_cities_all_time %></span>
|
|
</div>
|
|
<div class="all-time-stat">
|
|
<span class="label">Total distance</span>
|
|
<span class="value"><%= distance_with_unit(@digest.total_distance_all_time, @distance_unit) %></span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="footer">
|
|
<p>Powered by <a href="https://dawarich.app">Dawarich</a>, your personal location history.</p>
|
|
<p class="unsubscribe">
|
|
You can <a href="<%= settings_url(host: ENV.fetch('DOMAIN', 'localhost')) %>">manage your email preferences</a> in settings.
|
|
</p>
|
|
</div>
|
|
</body>
|
|
</html>
|