mirror of
https://github.com/we-promise/sure.git
synced 2026-04-18 11:34:13 +00:00
* Support all currencies, handle outside DB * Remove currencies from seed * Fix account balance namespace * Set default currency on authentication * Cache currency instances * Implement multi-currency syncs with tests * Series fallback, passing tests * Fix conflicts * Make value group concrete class that works with currency values * Fix migration conflict * Update tests to expect multi-currency results * Update account list to use group method * Namespace updates * Fetch unknown exchange rates from API * Fix date range bug * Ensure demo data works without external API * Enforce cascades only at DB level
50 lines
2.6 KiB
Plaintext
50 lines
2.6 KiB
Plaintext
<%# locals: (accountable_group:) %>
|
|
<% text_class = accountable_text_class(accountable_group.name) %>
|
|
<details class="open:bg-gray-25 group">
|
|
<summary class="flex p-4 items-center w-full rounded-lg font-medium hover:bg-gray-50 text-gray-500 text-sm font-medium cursor-pointer">
|
|
<%= lucide_icon("chevron-down", class: "hidden group-open:block w-5 h-5") %>
|
|
<%= lucide_icon("chevron-right", class: "group-open:hidden w-5 h-5") %>
|
|
<div class="ml-4 h-2.5 w-2.5 rounded-full <%= accountable_bg_class(accountable_group.name) %>"></div>
|
|
<p class="text-gray-900 ml-2"><%= to_accountable_title(Accountable.from_type(accountable_group.name)) %></p>
|
|
<span class="mx-1">·</span>
|
|
<div ><%= accountable_group.children.count %></div>
|
|
<div class="ml-auto text-right flex items-center gap-10 text-sm font-medium text-gray-900">
|
|
<div class="flex items-center justify-end gap-2 w-24">
|
|
<%= render partial: "shared/progress_circle", locals: { progress: accountable_group.percent_of_total, text_class: text_class } %>
|
|
<p><%= accountable_group.percent_of_total.round(1) %>%</p>
|
|
</div>
|
|
<div class="w-24">
|
|
<p><%= format_money accountable_group.sum %></p>
|
|
</div>
|
|
<div class="w-40">
|
|
<%= render partial: "shared/trend_change", locals: { trend: accountable_group.series.trend } %>
|
|
</div>
|
|
</div>
|
|
</summary>
|
|
<div class="px-4 py-3 space-y-4">
|
|
<% accountable_group.children.map do |account_value_node| %>
|
|
<div class="flex items-center justify-between text-sm font-medium text-gray-900">
|
|
<div class="flex items-center gap-4">
|
|
<div class="flex items-center justify-center w-8 h-8 rounded-full <%= text_class %> <%= accountable_bg_transparent_class(account_value_node.name) %>">
|
|
<%= account_value_node.name[0].upcase %>
|
|
</div>
|
|
<div>
|
|
<p><%= account_value_node.name %></p>
|
|
</div>
|
|
</div>
|
|
<div class="flex gap-10 items-center text-right">
|
|
<div class="flex items-center justify-end gap-2 w-24">
|
|
<%= render partial: "shared/progress_circle", locals: { progress: account_value_node.percent_of_total, text_class: text_class } %>
|
|
<p><%= account_value_node.percent_of_total %>%</p>
|
|
</div>
|
|
<div class="w-24">
|
|
<p><%= format_money account_value_node.original.balance_money %></p>
|
|
</div>
|
|
<div class="w-40">
|
|
<%= render partial: "shared/trend_change", locals: { trend: account_value_node.original.series.trend } %>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<% end %>
|
|
</div>
|
|
</details> |