mmsc_app/app/controllers/admin/p_payments_controller.rb
Nicolas Bally a6aa1f6074 Initial
2020-05-25 11:40:11 +02:00

219 lines
4.9 KiB
Ruby

# -*- encoding : utf-8 -*-
class Admin::PPaymentsController < ApplicationController
layout "admin"
before_action :auth_admin
before_action :admin_space
def relances
params[:day] = 0 if params[:day].to_s == ""
params[:day] = params[:day].to_i
params[:importeds] = "0" if params[:importeds].to_s == ""
@relances = true
@p_documents = PDocument.where(:p_document_type_id => 4, :paid => false, :i_archive => false).where("echeance_date <= ?", (Time.now - params[:day].day).end_of_day).order("DATEDIFF(NOW(), echeance_date) ASC,created_at DESC")
if params[:importeds] == "0"
@p_documents = @p_documents.where(:imported => false)
end
@p_document_bruts = @p_documents
per_page = (params[:per_page] and params[:per_page] != "") ? params[:per_page] : 50
page = (params[:page] and params[:page] != "") ? params[:page] : 1
@p_documents = @p_documents.page(page).per(per_page)
end
def import_lettrage
if true
require 'csv'
csv_text = File.read("#{Rails.root}/import_csv/lettrage.csv", :encoding => 'UTF-8')
@csv = CSV.parse(csv_text, :headers => true, :col_sep => ";")
end
end
def import
if false
if params[:csv_file]
@file = params[:csv_file]
require 'csv'
csv_text = @file.tempfile.read.force_encoding('ISO-8859-1').encode('utf-8')
@csv = CSV.parse(csv_text, :headers => true, :col_sep => ";")
end
end
end
def import_arrondis
if false
@file = params[:csv_file]
require 'csv'
csv_text = File.read("#{Rails.root}/import_csv/reglements3.csv", :encoding => 'UTF-8')
@csv = CSV.parse(csv_text, :headers => true, :col_sep => ";")
end
end
def admin_space
@admin_space = "payments"
end
def index
@p_payments = PPayment.order("paid_at DESC").all
params[:remise] = 0 if !params[:remise]
#params[:p_payment_type_ids] = ["4", "41", "42"] if !params[:p_payment_type_ids]
params[:p_payment_type_ids] = params[:p_payment_type_ids] || []
if params[:p_payment_type_ids].size > 0
@p_payments = @p_payments.where(:p_payment_type_id => params[:p_payment_type_ids])
end
if params[:amount_min].to_s != ""
@p_payments = @p_payments.where("amount >= ?", params[:amount_min])
end
if params[:amount_max].to_s != ""
@p_payments = @p_payments.where("amount <= ?", params[:amount_max])
end
if params[:affected].to_s != ""
@p_payments = @p_payments.where("affected = ?", params[:affected].to_i)
end
if params[:remise].to_s != ""
@p_payments = @p_payments.where("remise = ?", params[:remise].to_i)
if params[:remise].to_s == "0"
@p_payments = @p_payments.where(:imported => false)
end
end
date_regex = /^(0[1-9]|[12][0-9]|3[01])[\/](0[1-9]|1[012])[\/](19|20)\d\d$/i
#params[:start] = Date.today.beginning_of_month.strftime('%d/%m/%Y') if !params[:start]
if params[:start] and params[:start] =~ date_regex
#fsfds = sdfsfd
@start = Date.parse(params[:start]).beginning_of_day
params[:start]= @start.strftime('%d/%m/%Y')
else
@start = nil
end
if true
#params[:stop] = Date.today.end_of_month.strftime('%d/%m/%Y') if !params[:stop]
if params[:stop].to_s != "" # and params[:stop] =~ date_regex
@stop = Date.parse(params[:stop]).end_of_day
params[:stop]= @stop.strftime('%d/%m/%Y')
else
@stop = nil
end
end
@p_payments = @p_payments.where("paid_at >= ?", @start) if @start
if @stop
@p_payments = @p_payments.where("paid_at <= ?", @stop.end_of_day)
end
per_page = (params[:per_page] and params[:per_page] != "") ? params[:per_page] : 50
page = (params[:page] and params[:page] != "") ? params[:page] : 1
@all_p_payments = @p_payments
@p_payments = @p_payments.page(page).per(per_page)
end
def show
@p_payment = PPayment.find(params[:id])
end
def new
@p_payment = PPayment.new(:p_payment_type_id => 41)
@p_payment.p_customer = PCustomer.find(params[:p_customer_id]) if params[:p_customer_id]
end
def edit
@p_payment = PPayment.find(params[:id])
end
def create
@p_payment = PPayment.new(params.require(:p_payment).permit!)
if @p_payment.save
#@p_payments = PPayment.all
else
render action: "new"
end
end
def update
@p_payment = PPayment.find(params[:id])
if @p_payment.update_attributes(params.require(:p_payment).permit!)
#@p_payments = PPayment.order("created_at ASC").all
else
render action: "edit"
end
end
def destroy
@p_payment = PPayment.find(params[:id])
@p_payment.destroy
end
end