mirror of
https://github.com/maybe-finance/maybe.git
synced 2025-08-07 06:25:19 +02:00
Since the very first 0.1.0-alpha.1 release, we've been moving quickly to add new features to the Maybe app. In doing so, some parts of the codebase have become outdated, unnecessary, or overly-complex as a natural result of this feature prioritization. Now that "core" Maybe is complete, we're moving into a second phase of development where we'll be working hard to improve the accuracy of existing features and build additional features on top of "core". This PR is a quick overhaul of the existing codebase aimed to: - Establish the brand new and simplified dashboard view (pictured above) - Establish and move towards the conventions introduced in Cursor rules and project design overview #1788 - Consolidate layouts and improve the performance of layout queries - Organize the core models of the Maybe domain (i.e. Account::Entry, Account::Transaction, etc.) and break out specific traits of each model into dedicated concerns for better readability - Remove stale / dead code from codebase - Remove overly complex code paths in favor of simpler ones
59 lines
2.5 KiB
Text
59 lines
2.5 KiB
Text
<%= content_for :header_nav do %>
|
|
<%= render "imports/nav", import: @import %>
|
|
<% end %>
|
|
|
|
<%= content_for :previous_path, import_configuration_path(@import) %>
|
|
|
|
<div class="space-y-4 mx-auto max-w-5xl">
|
|
<div class="text-center space-y-2 max-w-[400px] mx-auto mb-4">
|
|
<h2 class="text-3xl text-primary font-medium"><%= t(".title") %></h2>
|
|
<p class="text-secondary text-sm"><%= t(".description") %></p>
|
|
</div>
|
|
|
|
<% if @import.cleaned? %>
|
|
<div class="bg-white border border-tertiary rounded-lg p-3 flex items-center justify-between">
|
|
<div class="flex items-center gap-2">
|
|
<%= lucide_icon "check-circle", class: "w-4 h-4 text-green-500" %>
|
|
<p class="text-green-500">Your data has been cleaned</p>
|
|
</div>
|
|
|
|
<%= link_to "Next step", import_confirm_path(@import), class: "btn btn--primary" %>
|
|
</div>
|
|
<% else %>
|
|
<div class="bg-white border border-tertiary rounded-lg p-3 flex items-center justify-between">
|
|
<div class="flex items-center gap-2">
|
|
<%= lucide_icon "alert-triangle", class: "w-4 h-4 text-red-500" %>
|
|
<p class="text-red-500 text-sm"><%= t(".errors_notice") %></p>
|
|
</div>
|
|
|
|
<div class="flex justify-center">
|
|
<div class="bg-gray-50 rounded-lg inline-flex p-1 space-x-2 text-sm text-primary font-medium">
|
|
<%= link_to "All rows", import_clean_path(@import, per_page: params[:per_page], view: "all"), class: "p-2 rounded-lg #{params[:view] != 'errors' ? 'bg-white' : ''}" %>
|
|
<%= link_to "Error rows", import_clean_path(@import, per_page: params[:per_page], view: "errors"), class: "p-2 rounded-lg #{params[:view] == 'errors' ? 'bg-white' : ''}" %>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<% end %>
|
|
|
|
<div class="pb-12">
|
|
<div class="bg-gray-25 rounded-xl p-1 mb-6">
|
|
<div style="grid-template-columns: repeat(<%= @import.column_keys.count %>, 1fr)" class="grid items-center uppercase text-xs font-medium text-secondary py-3">
|
|
<% @import.column_keys.each do |key| %>
|
|
<div class="px-5"><%= import_col_label(key) %></div>
|
|
<% end %>
|
|
</div>
|
|
|
|
<div class="bg-white shadow-border-xs rounded-xl divide-y divide-alpha-black-200">
|
|
<% @rows.each do |row| %>
|
|
<%= render "import/rows/form", row: row %>
|
|
<% end %>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="fixed bottom-0 left-1/2 -translate-x-1/2 w-full p-12">
|
|
<div class="shadow-border-xs rounded-lg p-3 max-w-2xl mx-auto bg-white">
|
|
<%= render "shared/pagination", pagy: @pagy %>
|
|
</div>
|
|
</div>
|
|
</div>
|