mirror of
https://github.com/maybe-finance/maybe.git
synced 2025-07-23 07:09:39 +02:00
* Allow inline account creation when importing CSV * Sanitize numeric inputs for CSV * CSV import date validation * Lint fix
59 lines
2.6 KiB
Text
59 lines
2.6 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-screen-lg">
|
|
<div class="text-center space-y-2 max-w-[400px] mx-auto mb-4">
|
|
<h2 class="text-3xl text-gray-900 font-medium"><%= t(".title") %></h2>
|
|
<p class="text-gray-500 text-sm"><%= t(".description") %></p>
|
|
</div>
|
|
|
|
<% if @import.cleaned? %>
|
|
<div class="bg-white border border-alpha-black-100 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-alpha-black-100 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-gray-900 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-gray-500 py-3">
|
|
<% @import.column_keys.each do |key| %>
|
|
<div class="px-5"><%= import_col_label(key) %></div>
|
|
<% end %>
|
|
</div>
|
|
|
|
<div class="bg-white border border-alpha-black-200 rounded-xl shadow-xs 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="border border-alpha-black-100 rounded-lg p-3 max-w-screen-sm mx-auto bg-white shadow-xs">
|
|
<%= render "application/pagination", pagy: @pagy %>
|
|
</div>
|
|
</div>
|
|
</div>
|