sellers_controller.rb 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  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" ? 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
  20. end
  21. # GET /sellers/new
  22. def new
  23. @seller = Seller.new
  24. if current_user.usertype != "A"
  25. @pointsale_id = current_user.pointsale_id
  26. end
  27. end
  28. # GET /sellers/1/edit
  29. def edit
  30. @pointsale_id = @seller.pointsale_id
  31. end
  32. # POST /sellers
  33. # POST /sellers.json
  34. def create
  35. @seller = Seller.new(seller_params)
  36. if current_user.usertype != "A"
  37. @seller.skip_pointsale = true
  38. @seller.pointsale_id = current_user.pointsale_id
  39. end
  40. respond_to do |format|
  41. message = "El vendedor " + @seller.full_name + " fue registrado."
  42. @seller.audit_comment = message
  43. if @seller.save
  44. format.html { redirect_to sellers_path, success: message }
  45. format.json { render :show, status: :created, location: @seller }
  46. else
  47. format.html { render :new }
  48. format.json { render json: @seller.errors, status: :unprocessable_entity }
  49. end
  50. end
  51. end
  52. # PATCH/PUT /sellers/1
  53. # PATCH/PUT /sellers/1.json
  54. def update
  55. respond_to do |format|
  56. message = "El vendedor " + @seller.full_name + " fue modificado."
  57. @seller.audit_comment = message
  58. if @seller.update(seller_params)
  59. format.html { redirect_to sellers_path, success: message }
  60. format.json { render :show, status: :ok, location: @seller }
  61. else
  62. format.html { render :edit }
  63. format.json { render json: @seller.errors, status: :unprocessable_entity }
  64. end
  65. end
  66. end
  67. def update_status
  68. seller = Seller.find(params[:seller_id])
  69. if seller.active?
  70. seller.status = 2
  71. elsif seller.inactive?
  72. seller.status = 1
  73. end
  74. respond_to do |format|
  75. message = "El vendedor " + seller.full_name + " " + seller.last_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" ? User.active : User.active.where(:pointsale_id => current_user.pointsale_id))
  121. @pointsales = Pointsale.activos
  122. end
  123. end