2024-06-12 15:10:53 -04:00
|
|
|
<% content_for :title, 'Statistics' %>
|
|
|
|
|
|
2024-11-28 09:54:36 -05:00
|
|
|
<div class="w-full my-5">
|
2024-04-17 15:05:31 -04:00
|
|
|
<div class="stats stats-vertical lg:stats-horizontal shadow w-full bg-base-200">
|
2024-03-23 16:16:11 -04:00
|
|
|
<div class="stat text-center">
|
|
|
|
|
<div class="stat-value text-primary">
|
2025-05-17 14:35:38 -04:00
|
|
|
<%= number_with_delimiter(current_user.total_distance) %> <%= current_user.safe_settings.distance_unit %>
|
2024-03-23 16:16:11 -04:00
|
|
|
</div>
|
|
|
|
|
<div class="stat-title">Total distance</div>
|
|
|
|
|
</div>
|
|
|
|
|
|
2024-03-24 13:55:35 -04:00
|
|
|
<div class="stat text-center">
|
|
|
|
|
<div class="stat-value text-success">
|
2024-12-02 08:44:22 -05:00
|
|
|
<%= number_with_delimiter @points_total %>
|
2024-03-24 13:55:35 -04:00
|
|
|
</div>
|
|
|
|
|
<div class="stat-title">Geopoints tracked</div>
|
|
|
|
|
</div>
|
|
|
|
|
|
2025-01-07 07:41:09 -05:00
|
|
|
<% if DawarichSettings.reverse_geocoding_enabled? %>
|
2024-06-07 15:22:57 -04:00
|
|
|
<%= render 'stats/reverse_geocoding_stats' %>
|
2024-03-24 13:09:00 -04:00
|
|
|
<% end %>
|
2024-03-23 16:16:11 -04:00
|
|
|
</div>
|
|
|
|
|
|
2024-12-20 09:26:25 -05:00
|
|
|
<%= link_to 'Update stats', update_all_stats_path, data: { turbo_method: :put }, class: 'btn btn-primary mt-5' %>
|
2024-03-24 14:25:33 -04:00
|
|
|
|
2024-12-20 09:26:25 -05:00
|
|
|
<div class="mt-6 grid grid-cols-1 sm:grid-cols-1 md:grid-cols-2 lg:grid-cols-2 gap-6">
|
2024-03-28 10:11:59 -04:00
|
|
|
<% @stats.each do |year, stats| %>
|
|
|
|
|
<div class="card w-full bg-base-200 shadow-xl">
|
|
|
|
|
<div class="card-body">
|
2024-12-20 09:26:25 -05:00
|
|
|
<h2 class="card-title justify-between text-<%= header_colors.sample %>">
|
|
|
|
|
<div>
|
|
|
|
|
<%= link_to year, "/stats/#{year}", class: 'underline hover:no-underline' %>
|
|
|
|
|
<%= link_to '[Map]', map_url(year_timespan(year)), class: 'underline hover:no-underline' %>
|
|
|
|
|
</div>
|
2025-05-15 12:23:24 -04:00
|
|
|
<div class="gap-2">
|
|
|
|
|
<span class='text-xs text-gray-500'>Last updated: <%= human_date(stats.first.updated_at) %></span>
|
|
|
|
|
<%= link_to '🔄', update_year_month_stats_path(year, :all), data: { turbo_method: :put }, class: 'text-sm text-gray-500 hover:underline' %>
|
|
|
|
|
</div>
|
2024-03-28 10:11:59 -04:00
|
|
|
</h2>
|
2024-04-02 11:37:38 -04:00
|
|
|
<p>
|
2024-08-28 17:54:00 -04:00
|
|
|
<% cache [current_user, 'year_distance_stat', year], skip_digest: true do %>
|
2025-05-17 14:35:38 -04:00
|
|
|
<%= number_with_delimiter year_distance_stat(year, current_user) %><%= current_user.safe_settings.distance_unit %>
|
2024-06-07 15:22:57 -04:00
|
|
|
<% end %>
|
2024-04-02 11:37:38 -04:00
|
|
|
</p>
|
2025-01-07 07:41:09 -05:00
|
|
|
<% if DawarichSettings.reverse_geocoding_enabled? %>
|
2024-03-28 10:11:59 -04:00
|
|
|
<div class="card-actions justify-end">
|
2025-05-17 18:15:25 -04:00
|
|
|
<% location_data = countries_and_cities_stat_for_year(year, stats) %>
|
|
|
|
|
<%= link_to "#{location_data[:countries_count]} countries, #{location_data[:cities_count]} cities",
|
|
|
|
|
"##{location_data[:modal_id]}",
|
|
|
|
|
class: "link link-primary",
|
|
|
|
|
onclick: "document.getElementById('#{location_data[:modal_id]}').checked = true" %>
|
|
|
|
|
|
|
|
|
|
<!-- Modal structure -->
|
|
|
|
|
<div>
|
|
|
|
|
<input type="checkbox" id="<%= location_data[:modal_id] %>" class="modal-toggle" />
|
|
|
|
|
<div class="modal" role="dialog">
|
|
|
|
|
<div class="modal-box max-w-3xl">
|
|
|
|
|
<h3 class="text-lg font-bold mb-4">Countries and Cities visited in <%= location_data[:year] %></h3>
|
|
|
|
|
<div class="max-h-96 overflow-y-auto">
|
|
|
|
|
<% location_data[:grouped_by_country].each do |country, cities| %>
|
|
|
|
|
<div class="mb-4">
|
|
|
|
|
<h4 class="font-bold">
|
|
|
|
|
<span class="mr-2"><%= country_flag(country) %></span>
|
|
|
|
|
<%= country %>
|
|
|
|
|
</h4>
|
|
|
|
|
<% if cities.any? %>
|
|
|
|
|
<div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-2 pl-4">
|
|
|
|
|
<% cities.each do |city| %>
|
|
|
|
|
<div class="text-sm"><%= city %></div>
|
|
|
|
|
<% end %>
|
|
|
|
|
</div>
|
|
|
|
|
<% else %>
|
|
|
|
|
<p class="text-sm text-gray-500 italic pl-4">No specific cities recorded</p>
|
|
|
|
|
<% end %>
|
|
|
|
|
</div>
|
|
|
|
|
<% end %>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<label class="modal-backdrop" for="<%= location_data[:modal_id] %>"></label>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
2024-03-28 10:11:59 -04:00
|
|
|
</div>
|
|
|
|
|
<% end %>
|
|
|
|
|
<%= column_chart(
|
2025-07-08 12:10:10 -04:00
|
|
|
Stat.year_distance(year, current_user).map { |month_name, distance_meters|
|
|
|
|
|
[month_name, Stat.convert_distance(distance_meters, current_user.safe_settings.distance_unit).round(2)]
|
|
|
|
|
},
|
2024-03-28 10:11:59 -04:00
|
|
|
height: '200px',
|
2025-05-17 14:35:38 -04:00
|
|
|
suffix: " #{current_user.safe_settings.distance_unit}",
|
2024-03-28 10:11:59 -04:00
|
|
|
xtitle: 'Days',
|
|
|
|
|
ytitle: 'Distance'
|
|
|
|
|
) %>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<% end %>
|
|
|
|
|
</div>
|
2024-03-23 15:29:55 -04:00
|
|
|
</div>
|