special_prices_controller.rb 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. class SpecialPricesController < ApplicationController
  2. ##--- Abilities
  3. load_and_authorize_resource
  4. ##--- Breadcrum_rails
  5. add_breadcrumb "Nuevo precio(s) especial", :new_special_price_path, only: :new
  6. before_action :set_special_price, only: [:update, :destroy]
  7. # GET /special_prices/new
  8. def new
  9. @special_price = SpecialPrice.new
  10. end
  11. # POST /special_prices
  12. # POST /special_prices.json
  13. def create
  14. @special_price = SpecialPrice.new(special_price_params)
  15. @special_price.user_id = current_user.id
  16. existence = SpecialPrice.where(product_id: @special_price.product_id, customer_id: @special_price.customer_id).any?
  17. @variantes = Product.where(parent_id: @special_price.product_id)
  18. respond_to do |format|
  19. if existence == true
  20. @error = true
  21. else
  22. @special_price.save
  23. end
  24. format.js
  25. end
  26. end
  27. # PATCH/PUT /special_prices/1
  28. # PATCH/PUT /special_prices/1.json
  29. def update
  30. respond_to do |format|
  31. if params[:special_price][:percent].blank?
  32. @special_price.percent = nil
  33. else
  34. @special_price.price = nil
  35. end
  36. @special_price.audit_comment = "Precio especial #{@special_price.product.name} #{@special_price.product.display_attributes} con #{'$' + params[:special_price][:price] if params[:special_price][:price].present?} #{params[:special_price][:percent] + '%' if params[:special_price][:percent].present?} de descuento"
  37. if @special_price.update(special_price_params)
  38. format.html { redirect_to @special_price, notice: 'Special price was successfully updated.' }
  39. format.json { head :no_content }
  40. else
  41. format.html { render :edit }
  42. format.json { render json: @special_price.errors, status: :unprocessable_entity }
  43. end
  44. end
  45. end
  46. # DELETE /special_prices/1
  47. # DELETE /special_prices/1.json
  48. def destroy
  49. @special_price.audit_comment = "Precio especial #{@special_price.product.name} #{@special_price.product.display_attributes} eliminado"
  50. @special_price.destroy
  51. respond_to do |format|
  52. format.html { redirect_to special_prices_url, notice: 'Special price was successfully destroyed.' }
  53. format.json { head :no_content }
  54. end
  55. end
  56. def get_special_price_by_customer
  57. @special_prices = SpecialPrice.includes(:product).where(customer_id: params[:customer_id]).order("id ASC")
  58. respond_to do |format|
  59. format.js
  60. end
  61. end
  62. def add_special_price_by_barcode
  63. respond_to do |format|
  64. @product = Product.find_by(barcode: params[:barcode])
  65. unless @product.blank?
  66. @special_price = SpecialPrice.new
  67. @special_price.product_id = @product.id
  68. @special_price.customer_id = params[:customer_id]
  69. @special_price.user_id = current_user.id
  70. @existence = SpecialPrice.where(product_id: @special_price.product_id, customer_id: @special_price.customer_id).any?
  71. @special_price.save
  72. end
  73. format.js
  74. end
  75. end
  76. private
  77. # Use callbacks to share common setup or constraints between actions.
  78. def set_special_price
  79. @special_price = SpecialPrice.find(params[:id])
  80. end
  81. # Never trust parameters from the scary internet, only allow the white list through.
  82. def special_price_params
  83. params.require(:special_price).permit(:product_id, :customer_id, :price, :percent, :status, :user_id)
  84. end
  85. end