2024-10-01 10:47:59 -04:00
|
|
|
class Import::UploadsController < ApplicationController
|
|
|
|
layout "imports"
|
|
|
|
|
|
|
|
before_action :set_import
|
|
|
|
|
|
|
|
def show
|
|
|
|
end
|
|
|
|
|
|
|
|
def update
|
|
|
|
if csv_valid?(csv_str)
|
2025-03-03 12:47:30 -05:00
|
|
|
@import.account = Current.family.accounts.find_by(id: params.dig(:import, :account_id))
|
2024-10-01 10:47:59 -04:00
|
|
|
@import.assign_attributes(raw_file_str: csv_str, col_sep: upload_params[:col_sep])
|
|
|
|
@import.save!(validate: false)
|
|
|
|
|
2025-03-04 13:10:01 -05:00
|
|
|
redirect_to import_configuration_path(@import, template_hint: true), notice: "CSV uploaded successfully."
|
2024-10-01 10:47:59 -04:00
|
|
|
else
|
|
|
|
flash.now[:alert] = "Must be valid CSV with headers and at least one row of data"
|
|
|
|
|
|
|
|
render :show, status: :unprocessable_entity
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
def set_import
|
|
|
|
@import = Current.family.imports.find(params[:import_id])
|
|
|
|
end
|
|
|
|
|
|
|
|
def csv_str
|
|
|
|
@csv_str ||= upload_params[:csv_file]&.read || upload_params[:raw_file_str]
|
|
|
|
end
|
|
|
|
|
|
|
|
def csv_valid?(str)
|
|
|
|
begin
|
2025-02-28 12:21:07 -05:00
|
|
|
csv = Import.parse_csv_str(str, col_sep: upload_params[:col_sep])
|
2024-10-01 10:47:59 -04:00
|
|
|
return false if csv.headers.empty?
|
|
|
|
return false if csv.count == 0
|
|
|
|
true
|
|
|
|
rescue CSV::MalformedCSVError
|
|
|
|
false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def upload_params
|
|
|
|
params.require(:import).permit(:raw_file_str, :csv_file, :col_sep)
|
|
|
|
end
|
|
|
|
end
|