sellers_controller.rb 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. class SellersController < ApplicationController
  2. ##--- Abilities
  3. load_and_authorize_resource
  4. before_action :set_seller, only: [:show, :edit, :update, :destroy]
  5. before_action :get_info, only: [:new, :edit, :create, :update]
  6. before_action :get_filters, only: [:index, :show, :edit, :new]
  7. ##--- Breadcrum_rails
  8. add_breadcrumb I18n.t("breadcrumbs." + controller_name), :sellers_path
  9. add_breadcrumb "Nuevo vendedor ", :new_seller_path, only: :new
  10. add_breadcrumb "Detalle del vendedor ", :seller_path, only: :show
  11. add_breadcrumb "Editar vendedor ", :edit_seller_path, only: :edit
  12. # GET /sellers
  13. # GET /sellers.json
  14. def index
  15. @sellers = current_user.usertype == "A" || current_user.usertype == "SS" ? Seller.vigentes.includes(:pointsale) : Seller.where(pointsale_id: current_user.pointsale_id).vigentes
  16. end
  17. # GET /sellers/1
  18. # GET /sellers/1.json
  19. def show; end
  20. # GET /sellers/new
  21. def new
  22. @seller = Seller.new
  23. if current_user.usertype != "A" || current_user.usertype != "SS"
  24. @pointsale_id = current_user.pointsale_id
  25. end
  26. end
  27. # GET /sellers/1/edit
  28. def edit
  29. @pointsale_id = @seller.pointsale_id
  30. end
  31. # POST /sellers
  32. # POST /sellers.json
  33. def create
  34. @seller = Seller.new(seller_params)
  35. unless current_user.usertype == "A" || current_user.usertype == "SS"
  36. @seller.skip_pointsale = true
  37. @seller.pointsale_id = current_user.pointsale_id
  38. end
  39. respond_to do |format|
  40. message = "El vendedor " + @seller.full_name + " fue registrado."
  41. @seller.audit_comment = message
  42. if @seller.save
  43. format.js
  44. else
  45. format.html { render :new }
  46. format.js
  47. format.json { render json: @seller.errors, status: :unprocessable_entity }
  48. end
  49. end
  50. end
  51. # PATCH/PUT /sellers/1
  52. # PATCH/PUT /sellers/1.json
  53. def update
  54. respond_to do |format|
  55. message = "El vendedor " + @seller.full_name + " fue modificado."
  56. @seller.audit_comment = message
  57. if @seller.update(seller_params)
  58. format.js
  59. else
  60. format.html { render :edit }
  61. format.js
  62. format.json { render json: @seller.errors, status: :unprocessable_entity }
  63. end
  64. end
  65. end
  66. def update_status
  67. seller = Seller.find(params[:seller_id])
  68. seller.status =
  69. if seller.active?
  70. 2
  71. elsif seller.inactive?
  72. 1
  73. end
  74. respond_to do |format|
  75. message = "El vendedor " + seller.full_name + " fue " + (seller.active? ? "activado" : "desactivado") + "."
  76. seller.audit_comment = message
  77. if seller.save(validate: false)
  78. format.html { redirect_to sellers_url, warning: message }
  79. format.json { head :no_content }
  80. else
  81. format.html { redirect_to sellers_url }
  82. format.json { render json: @seller.errors, status: :unprocessable_entity }
  83. end
  84. end
  85. end
  86. # DELETE /sellers/1
  87. # DELETE /sellers/1.json
  88. def destroy
  89. #@expensesconcept.destroy
  90. respond_to do |format|
  91. message = "El vendedor " + @seller.full_name + " fue eliminado."
  92. @seller.audit_comment = message
  93. if @seller.update_attributes(status: 0)
  94. format.html { redirect_to sellers_path, warning: message }
  95. format.json { head :no_content }
  96. else
  97. format.html { render :edit }
  98. format.json { render json: @seller.errors, status: :unprocessable_entity }
  99. end
  100. end
  101. end
  102. private
  103. # Use callbacks to share common setup or constraints between actions.
  104. def set_seller
  105. @seller = Seller.find(params[:id])
  106. end
  107. # Never trust parameters from the scary internet, only allow the white list through.
  108. def seller_params
  109. params.require(:seller).permit(:pointsale_id, :name, :last_name)
  110. end
  111. def get_filters
  112. if params[:current_page].blank?
  113. @current_page = 1
  114. else
  115. @current_page = params[:current_page]
  116. end
  117. @filter = params[:filter]
  118. end
  119. def get_info
  120. @users = (current_user.usertype == "A" || current_user.usertype == "SS" ? User.active : User.active.where(pointsale_id: current_user.pointsale_id))
  121. @pointsales = Pointsale.activos
  122. end
  123. end