2025-02-21 11:57:59 -05:00
|
|
|
<%# locals: (balance_sheet:) %>
|
|
|
|
|
|
|
|
<div class="space-y-4">
|
|
|
|
<% balance_sheet.classification_groups.each do |classification_group| %>
|
2025-04-11 09:28:00 -05:00
|
|
|
<div class="bg-container shadow-border-xs rounded-xl space-y-4 p-4">
|
2025-02-21 11:57:59 -05:00
|
|
|
<h2 class="text-lg font-medium"><%= classification_group.display_name %></h2>
|
|
|
|
|
|
|
|
<% if classification_group.account_groups.any? %>
|
|
|
|
<div class="space-y-4">
|
|
|
|
<div class="flex gap-1">
|
|
|
|
<% classification_group.account_groups.each do |account_group| %>
|
|
|
|
<div class="h-1.5 rounded-sm" style="width: <%= account_group.weight %>%; background-color: <%= account_group.color %>;"></div>
|
|
|
|
<% end %>
|
|
|
|
</div>
|
2025-03-21 20:18:12 +03:00
|
|
|
<div class="flex flex-wrap gap-4">
|
2025-02-21 11:57:59 -05:00
|
|
|
<% classification_group.account_groups.each do |account_group| %>
|
|
|
|
<div class="flex items-center gap-2 text-sm">
|
|
|
|
<div class="h-2.5 w-2.5 rounded-full" style="background-color: <%= account_group.color %>;"></div>
|
|
|
|
<p class="text-secondary"><%= account_group.name %></p>
|
2025-02-25 17:28:40 -05:00
|
|
|
<p class="text-black font-mono"><%= number_to_percentage(account_group.weight, precision: 0) %></p>
|
2025-02-21 11:57:59 -05:00
|
|
|
</div>
|
|
|
|
<% end %>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="bg-surface rounded-xl p-1 space-y-1">
|
|
|
|
<div class="px-4 py-2 flex items-center uppercase text-xs font-medium text-secondary">
|
2025-04-18 18:53:10 +05:30
|
|
|
<div class="hidden sm:block">Name</div>
|
2025-02-21 11:57:59 -05:00
|
|
|
<div class="ml-auto text-right flex items-center gap-6">
|
|
|
|
<div class="w-24">
|
|
|
|
<p>Weight</p>
|
|
|
|
</div>
|
|
|
|
<div class="w-40">
|
|
|
|
<p>Value</p>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
2025-04-11 09:28:00 -05:00
|
|
|
<div class="shadow-border-xs rounded-lg bg-container">
|
2025-02-21 11:57:59 -05:00
|
|
|
<% classification_group.account_groups.each do |account_group| %>
|
|
|
|
<details class="group rounded-lg open:bg-surface font-medium text-sm">
|
2025-04-11 09:28:00 -05:00
|
|
|
<summary class="cursor-pointer p-4 group-open:bg-surface bg-container rounded-lg flex items-center justify-between">
|
2025-04-18 18:53:10 +05:30
|
|
|
<div class="items-center gap-4 hidden md:flex">
|
2025-02-21 11:57:59 -05:00
|
|
|
<%= lucide_icon("chevron-right", class: "group-open:rotate-90 text-secondary w-5 h-5") %>
|
|
|
|
|
|
|
|
<p><%= account_group.name %></p>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="ml-auto flex items-center text-right gap-6">
|
|
|
|
<div class="w-24 flex items-center justify-end gap-2">
|
2025-04-18 18:53:10 +05:30
|
|
|
<div class="hidden sm:flex sm:items-center sm:justify-end sm:gap-2">
|
|
|
|
<%= render partial: "shared/progress_circle", locals: { progress: account_group.weight, color: account_group.color } %>
|
|
|
|
<p><%= number_to_percentage(account_group.weight, precision: 0) %></p>
|
|
|
|
</div>
|
|
|
|
<div class="flex sm:hidden items-center gap-2">
|
|
|
|
<div class="flex gap-[3px]">
|
|
|
|
<% 10.times do |i| %>
|
|
|
|
<div class="w-[2px] h-[10px] rounded-lg <%= i < (account_group.weight / 10.0).ceil ? '' : 'opacity-20' %>" style="background-color: <%= account_group.color %>;"></div>
|
|
|
|
<% end %>
|
|
|
|
</div>
|
|
|
|
<p class="text-sm"><%= number_to_percentage(account_group.weight, precision: 2) %></p>
|
|
|
|
</div>
|
2025-02-21 11:57:59 -05:00
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="w-40">
|
|
|
|
<p><%= format_money(account_group.total_money) %></p>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</summary>
|
|
|
|
|
|
|
|
<div>
|
|
|
|
<% account_group.accounts.each_with_index do |account, idx| %>
|
2025-04-18 18:53:10 +05:30
|
|
|
<div class="pl-4 sm:pl-12 pr-4 py-3 flex items-center justify-between text-sm font-medium">
|
|
|
|
<div class="hidden sm:flex sm:items-center sm:gap-3">
|
2025-02-21 11:57:59 -05:00
|
|
|
<%= render "accounts/logo", account: account, size: "sm", color: account_group.color %>
|
|
|
|
<%= link_to account.name, account_path(account) %>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="ml-auto flex items-center text-right gap-6">
|
|
|
|
<div class="w-24 flex items-center justify-end gap-2">
|
2025-04-18 18:53:10 +05:30
|
|
|
<div class="hidden sm:flex sm:items-center sm:justify-end sm:gap-2">
|
|
|
|
<%= render partial: "shared/progress_circle", locals: { progress: account.weight, color: account_group.color } %>
|
|
|
|
<p><%= number_to_percentage(account.weight, precision: 0) %></p>
|
|
|
|
</div>
|
|
|
|
<div class="flex sm:hidden items-center gap-2">
|
|
|
|
<div class="flex gap-[3px]">
|
|
|
|
<% 10.times do |i| %>
|
|
|
|
<div class="w-[2px] h-[10px] rounded-lg <%= i < (account.weight / 10.0).ceil ? '' : 'opacity-20' %>" style="background-color: <%= account_group.color %>;"></div>
|
|
|
|
<% end %>
|
|
|
|
</div>
|
|
|
|
<p class="text-sm"><%= number_to_percentage(account.weight, precision: 2) %></p>
|
|
|
|
</div>
|
2025-02-21 11:57:59 -05:00
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="w-40">
|
|
|
|
<p><%= format_money(account.balance_money) %></p>
|
2025-04-18 18:53:10 +05:30
|
|
|
<div class="sm:hidden text-xs text-secondary truncate max-w-28">
|
|
|
|
<%= account.name %>
|
|
|
|
</div>
|
2025-02-21 11:57:59 -05:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<% if idx < account_group.accounts.size - 1 %>
|
|
|
|
|
|
|
|
<div class="pl-[84px] pr-40">
|
|
|
|
<div class="w-full border-subdued border-b"></div>
|
|
|
|
</div>
|
|
|
|
<% end %>
|
|
|
|
<% end %>
|
|
|
|
</div>
|
|
|
|
</details>
|
|
|
|
<% end %>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<% else %>
|
|
|
|
<div class="py-20 flex flex-col items-center">
|
|
|
|
<%= lucide_icon classification_group.icon, class: "w-6 h-6 shrink-0 text-secondary" %>
|
|
|
|
<p class="text-primary text-sm font-medium mb-1 mt-4">No <%= classification_group.display_name %></p>
|
|
|
|
<p class="text-secondary text-sm max-w-xs text-center"><%= "You have no #{classification_group.display_name}" %></p>
|
|
|
|
</div>
|
|
|
|
<% end %>
|
|
|
|
</div>
|
|
|
|
<% end %>
|
|
|
|
</div>
|