0

I am using model validation I want to load the default layout with register.html.erb page. But while i am using rendering only register my layout not loading. Please check -

#users_controller.rb
def create
    @user = User.new(create_user_params)
    #raise @user.inspect
    respond_to do |format|
      if @user.save
        format.html { redirect_to :success, notice: 'Registration was successfully created.' }
        format.json { render :success, status: :created, location: @users }
      else
        format.html { render :register }
        format.json { render json: @users.errors, status: :unprocessable_entity }
      end
    end
  end

Here is format.html { render :register } I have successfully getting my validating error message. But design missing only loading register.html.erb. Complete page not coming with layout.If I am using redirect_to :register instead of render :register my page redirect successfully to register page but my error message not showing.

How I will showing both my validating error and design?

users_controller.rb

class UsersController < ApplicationController
  before_action :set_user, only: [:show, :edit, :destroy, :register_success]


  # GET /users
  # GET /users.json  
  def index
    @users = User.all
  end

  # GET /users/1
  # GET /users/1.json
  def show
  end

  # GET /users/new
  def new
    @user = User.new
  end

  # GET /users/1/edit
  def edit
  end

  #=============================CHINU CODE START
  def login
    @title = 'Login'
    render layout: 'login'
  end
  def create_login
    user = User.authenticate(params[:user][:username], params[:user][:password])
    if user
      log_in @user
      redirect_to @user
    else
      flash[:danger] = 'Invalid email/password combination' # Not quite right!
      redirect_to :back
    end
  end
  def register
    @user = User.new
    @title = 'Register'
    render layout: 'login'
  end

  def create
    @user = User.new(create_user_params)
    #raise @user.inspect
    respond_to do |format|
      if @user.save
        format.html { redirect_to @users, notice: 'Registration was successfully created.' }
        format.json { redirect_to :success, status: :created, location: @users }
      else
        format.html { render :register }
        format.json { render json: @users.errors, status: :unprocessable_entity }
      end
    end
  end

  def register_success
    raise @user.inspect
  end

  def check_email    
    email = params[:user]
    user = User.where("email = ?", email).first
    if user.present?
      render :json =>  [false , "This email is already taken"]
    else
      render :json =>  [true , "Email available"]
    end
  end
  def check_username   
    username = params[:user]
    user = User.where("username = ?", username).first
    if user.present?
      render :json =>  [false , "Username has already been taken"]
    else
      render :json =>  [true , "Username available"]
    end
  end
  #=============================CHINU CODE END

  private
  # Use callbacks to share common setup or constraints between actions.
  def set_user
    @user = User.find(params[:id])
  end

  # Never trust parameters from the scary internet, only allow the white list through.
  def user_params
    params.require(:user).permit(:name, :username, :email, :password, :image, :dob, :photo, :address)
  end
  def create_user_params
    params.require(:user).permit(:name, :username, :email, :password, :dob, :address)
  end

  def login_user_params
    params.require(:user).permit(:username, :password, :password_confirmation)
  end
end

application_controller.rb

class ApplicationController < ActionController::Base
  # Prevent CSRF attacks by raising an exception.
  # For APIs, you may want to use :null_session instead.
  protect_from_forgery with: :exception
  include SessionsHelper

end
Chinmay235
  • 3,236
  • 8
  • 62
  • 93

0 Answers0