cash_registers_moves_controller.rb 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292
  1. class CashRegistersMovesController < ApplicationController
  2. before_action :set_cash_registers_move, only: [:show, :edit, :update, :destroy]
  3. # GET /cash_registers_moves/new
  4. def new
  5. @cash_registers_move = CashRegistersMove.new
  6. if params[:sale].present?
  7. @sale = Sale.find(params[:sale])
  8. @credito = Credit.where(customer_id: @sale.customer_id, status: "0").sum(:rest)
  9. @cash_registers_move.open_cash_register_id = @sale.open_cash_register_id
  10. elsif params[:products_return].present?
  11. @products_return = ProductsReturn.find(params[:products_return])
  12. end
  13. @cash_id = PaymentMethod.find_by(isCash: 1).id
  14. if @sale.present?
  15. if @sale.saletype == 'reserved'
  16. if @sale.parcial?
  17. # esto quiere decir que la venta ya tiene un anticipo, se debe mostrar modal
  18. # para abonar al apartado o liquidarlo
  19. @payments = CashRegistersMove.where(sale_id: @sale.id, status: 1)
  20. render 'liquidate_reserved_sale'
  21. else
  22. # registrar apartado
  23. @min_quantity_reserve = ((@pos_config.reserve_sale_percent / 100) * @sale.total).round
  24. @cash_registers_move.quantity = @min_quantity_reserve
  25. render 'new_sale_reserve'
  26. end
  27. else
  28. # Nueva venta
  29. render 'new'
  30. end
  31. elsif @products_return.present?
  32. @open_cash_register_id = session[:open_cash_register_id]
  33. render 'products_return_payment'
  34. end
  35. end
  36. # POST /cash_registers_moves
  37. # POST /cash_registers_moves.json
  38. # rubocop:disable Metrics/BlockLength
  39. def create
  40. @cash_registers_move = CashRegistersMove.new(cash_registers_move_params)
  41. @sale = Sale.find(params[:cash_registers_move][:sale_id]) if params[:cash_registers_move][:sale_id].present?
  42. @purchase = Purchase.find(params[:cash_registers_move][:purchase_id]) if params[:cash_registers_move][:purchase_id].present?
  43. credit = Credit.find_by_sale_id(@sale.id) if params[:cash_registers_move][:sale_id].present?
  44. @products_return = ProductsReturn.find(params[:cash_registers_move][:products_return_id]) if params[:cash_registers_move][:products_return_id].present?
  45. respond_to do |format|
  46. if @sale.present?
  47. # calcular cambio cuando aplica.
  48. @cash_registers_move.calculate_quantities
  49. @cash_registers_move.move_type = :ingreso
  50. if @sale.cash?
  51. @sale.update_attributes(status: :paid)
  52. @cash_registers_move.concept = :sale
  53. elsif @sale.reserved?
  54. @cash_registers_move.status = :inactive
  55. @cash_registers_move.concept = :reserved_payment
  56. @cash_registers_move.open_cash_register_id = session[:open_cash_register_id]
  57. end
  58. if credit.present?
  59. save_when_is_credit(credit)
  60. @cash_registers_move.open_cash_register_id = session[:open_cash_register_id]
  61. end
  62. message = "movimiento de efectivo por venta con folio #{@cash_registers_move.sale.sale_code}"
  63. @cash_registers_move.audit_comment = message
  64. if @cash_registers_move.save
  65. format.js { flash[:success] = message }
  66. else
  67. format.js
  68. format.json { render json: @cash_registers_move.errors, status: :unprocessable_entity }
  69. end
  70. elsif @purchase.present?
  71. @cash_registers_move.move_type = :egreso
  72. @cash_registers_move.concept = :purchase
  73. @cash_registers_move.status = :inactive
  74. message = "movimiento de efectivo por compra con folio #{@cash_registers_move.purchase.purchase_code}"
  75. @cash_registers_move.audit_comment = message
  76. if @cash_registers_move.save
  77. format.html { redirect_to purchases_path, success: 'Movimiento de efectivo realizado correctamente.' }
  78. else
  79. format.html { render :new }
  80. format.json { render json: @cash_registers_move.errors, status: :unprocessable_entity }
  81. end
  82. elsif @products_return.present?
  83. # calcular cambio cuando aplica.
  84. @cash_registers_move.calculate_quantities
  85. @cash_registers_move.move_type = :ingreso
  86. @cash_registers_move.status = :inactive
  87. message = "movimiento de efectivo por devolución con folio #{@cash_registers_move.products_return.return_code}"
  88. @cash_registers_move.audit_comment = message
  89. if @cash_registers_move.save
  90. format.js { flash[:success] = message }
  91. else
  92. format.js
  93. format.json { render json: @cash_registers_move.errors, status: :unprocessable_entity }
  94. end
  95. end
  96. end
  97. end
  98. # rubocop:enable Metrics/BlockLength
  99. # DELETE /cash_registers_moves/1
  100. # DELETE /cash_registers_moves/1.json
  101. def destroy
  102. @cash_registers_move.destroy
  103. respond_to do |format|
  104. format.json { head :no_content }
  105. format.js { head :ok }
  106. end
  107. end
  108. def confirm_payments
  109. respond_to do |format|
  110. @sale = Sale.find(params[:sale_id]) if params[:sale_id].present?
  111. @products_return = ProductsReturn.find(params[:products_return_id]) if params[:products_return_id].present?
  112. if @sale.present?
  113. if CashRegistersMove.where(sale_id: @sale.id).update_all(status: 1)
  114. @sale.update_attributes(status: :paid)
  115. message = "Venta registrada correctamente."
  116. end
  117. elsif @products_return.present?
  118. CashRegistersMove.where(products_return_id: @products_return.id).update_all(status: 1)
  119. message = "Devolución registrada correctamente."
  120. end
  121. format.js { flash[:success] = message }
  122. end
  123. end
  124. # funcion que se manda llamar cuando se clickea en 'Abonar' al crear apartado
  125. def confirm_reserve
  126. respond_to do |format|
  127. @sale = Sale.find(params[:sale_id])
  128. if CashRegistersMove.where(sale_id: @sale.id).update_all(status: 1)
  129. @sale.update_attributes(status: :parcial)
  130. format.js { flash[:success] = "Apartado agregado al cliente #{@sale.customer.nick_name} correctamente." }
  131. end
  132. end
  133. end
  134. def add_payments_to_reserve
  135. respond_to do |format|
  136. @sale = Sale.find(params[:sale_id])
  137. @new_moves_array = Array.new
  138. @new_moves = CashRegistersMove.where(sale_id: @sale.id, status: 0)
  139. @new_moves.each do |move|
  140. @new_moves_array << move.id
  141. end
  142. if @new_moves.update_all(status: 1)
  143. # if @sale.reserve_debt == 0
  144. if @sale.reserve_debt <= 0
  145. @sale.update_attributes(status: :paid)
  146. end
  147. format.js { flash[:success] = "Abono al apartado #{@sale.sale_code} agregado correctamente." }
  148. end
  149. end
  150. end
  151. # rubocop:disable Metrics/BlockLength
  152. def delete_credit_payment
  153. respond_to do |format|
  154. payment = CreditPayment.find(params[:credit_payment_id])
  155. cashmoves = CashRegistersMove.where(credit_payment_id: payment.id)
  156. openregister = OpenCashRegister.find_by(id: cashmoves.first.open_cash_register_id)
  157. if openregister.open?
  158. payment.update_attributes(status: :cancelled)
  159. credit = Credit.find(params[:credit])
  160. sale = Sale.find(credit.sale_id)
  161. sum = payment.quantity + credit.rest
  162. if credit.total < sum
  163. credit.update_attributes(rest: credit.total)
  164. sale.update_attributes(status: :notpaid)
  165. else
  166. credit.update_attributes(rest: sum)
  167. if sale.total == credit.rest
  168. sale.update_attributes(status: :notpaid)
  169. end
  170. end
  171. cashmoves.each do |move|
  172. new_cash_move = move.dup
  173. new_cash_move.move_type = :egreso
  174. new_cash_move.save
  175. end
  176. format.html { redirect_to customer_sales_path(customer_id: payment.customer_id), notice: "Movimiento de efectivo realizado correctamente." }
  177. format.js { flash[:success] = "Movimiento de efectivo realizado correctamente." }
  178. else
  179. format.html { redirect_to customer_sales_path(customer_id: payment.customer_id), notice: "No se pudo realizar el movimiento." }
  180. format.js { flash[:success] = "NO se pudo realizar el movimiento." }
  181. end
  182. end
  183. end
  184. # rubocop:enable Metrics/BlockLength
  185. def add_quick_payment
  186. # type 1 es abono a credito, 2 es abono a apartado
  187. @type = params[:type].to_i
  188. if @type == 1
  189. debtors_ids = Credit.debtors
  190. @customers = Customer.find(debtors_ids.map { |m| m[0] })
  191. else
  192. @sales = Pointsale.find(current_user.pointsale_id).sales.where(saletype: 2, status: 3).select(:customer_id).distinct
  193. # rubocop:disable Style/SymbolProc
  194. @customers = Customer.find(@sales.map { |m| m.customer_id })
  195. # rubocop:enable Style/SymbolProc
  196. end
  197. end
  198. def create_quick_debt_payment
  199. @customer = Customer.find(params[:customer_id])
  200. @sale = @customer.sales.where('saletype = 0 and status != 1 and status != 2').order('date_sale DESC').last
  201. redirect_to new_cash_registers_move_path(sale: @sale, customer: @customer)
  202. end
  203. private
  204. # Use callbacks to share common setup or constraints between actions.
  205. def set_cash_registers_move
  206. @cash_registers_move = CashRegistersMove.find(params[:id])
  207. end
  208. # Never trust parameters from the scary internet, only allow the white list through.
  209. def cash_registers_move_params
  210. params.require(:cash_registers_move).permit(:payment_method_id, :quantity, :open_cash_register_id, :sale_id, :cardnumber, :ticket, :received, :change, :products_return_id)
  211. end
  212. def save_when_is_credit(credit)
  213. abono = @cash_registers_move.quantity
  214. @credit_payment = CreditPayment.new
  215. @credit_payment.credit_id = credit.id
  216. @credit_payment.customer_id = credit.customer_id
  217. @credit_payment.pointsale_id = credit.pointsale_id
  218. @credit_payment.status = :active
  219. @credit_payment.date_payment = Date.today
  220. @credit_payment.user_id = current_user.id
  221. if @credit_payment.save
  222. @cash_registers_move.credit_payment_id = @credit_payment.id
  223. @cash_registers_move.concept = :credit_payment
  224. @debt = Credit.where(customer_id: credit.customer_id).sum(:rest)
  225. if abono >= credit.rest # si se paga mas del adeudo de este credito
  226. abono -= credit.rest
  227. # @debt = credit.rest
  228. credit.update_attributes(rest: 0)
  229. @sale.update_attributes(status: :paid)
  230. # rubocop:disable Style/WhileUntilDo
  231. while abono > 0 do
  232. nextcredit = Credit.where("customer_id = #{credit.customer_id} and rest > 0").order("sale_id ASC")
  233. # rubocop:disable Metrics/BlockNesting
  234. if nextcredit.first.present?
  235. if abono <= nextcredit.first.rest
  236. nextcredit.first.update_attributes(rest: nextcredit.first.rest - abono)
  237. sale = Sale.find_by_id(nextcredit.first.sale_id)
  238. sale.update_attributes(status: :parcial)
  239. abono -= nextcredit.first.rest
  240. else
  241. abono -= nextcredit.first.rest
  242. # @debt = nextcredit.first.rest
  243. nextcredit.first.update_attributes(rest: 0)
  244. sale = Sale.find_by_id(nextcredit.sale_id)
  245. sale.update_attributes(status: :paid)
  246. end
  247. else
  248. abono = 0 # si ya no hay deuda
  249. end
  250. # rubocop:enable Metrics/BlockNesting
  251. end
  252. # rubocop:enable Style/WhileUntilDo
  253. else
  254. @cash_registers_move.quantity = abono
  255. abono = credit.rest - abono
  256. credit.update_attributes(rest: abono)
  257. @sale.update_attributes(status: :parcial)
  258. end
  259. end
  260. end
  261. end