Commit eca18ec0 by nnnghia98

edit my page

parent 77947670
...@@ -8,6 +8,7 @@ class ApplicationController < ActionController::Base ...@@ -8,6 +8,7 @@ class ApplicationController < ActionController::Base
def configure_permitted_parameters def configure_permitted_parameters
added_attrs = [:username, :email, :password, :password_confirmation, :remember_me] added_attrs = [:username, :email, :password, :password_confirmation, :remember_me]
devise_parameter_sanitizer.permit :sign_up, keys: added_attrs devise_parameter_sanitizer.permit :sign_up, keys: added_attrs
devise_parameter_sanitizer.permit :account_update, keys: added_attrs
end end
def after_sign_in_path_for(resource) def after_sign_in_path_for(resource)
......
class Users::MyPageController < ApplicationController
def index
end
end
class Users::RegistrationsController < Devise::RegistrationsController
before_action :sign_up_params, only: :create
before_action :account_update_params, only: :update
private
def sign_up_params
params.require(:user).permit(:first_name, :last_name, :email, :password, :password_confirmation)
end
def account_update_params
params.require(:user).permit(:first_name, :last_name, :email, :password, :password_confirmation, :current_password)
end
end
...@@ -6,7 +6,7 @@ ...@@ -6,7 +6,7 @@
<ul class="list"> <ul class="list">
<% if user_signed_in? %> <% if user_signed_in? %>
Logged in as <strong><%= current_user.email %></strong> Logged in as <strong><%= current_user.email %></strong>
<li class="list-inline-item"></li><%= link_to "My Page", "#" %></li> <li class="list-inline-item"></li><%= link_to "My Page", my_path %></li>
<li class="list-inline-item"></li><%= link_to "Logout", destroy_user_session_path, method: :delete %></li> <li class="list-inline-item"></li><%= link_to "Logout", destroy_user_session_path, method: :delete %></li>
<% else %> <% else %>
<li class="list-inline-item"><%= link_to "Login", new_user_session_path %></li> <li class="list-inline-item"><%= link_to "Login", new_user_session_path %></li>
......
<h1>My Page</h1>
<div class="jumbotron">
<h3>Email: <%= current_user.email %></h3>
<h3>Full name: <%= current_user.first_name %> <%= current_user.last_name %></h3>
<h3>My CV</h3>
</div>
<div class="container">
<%= link_to "Update", edit_user_registration_path, class: "btn btn-lg btn-primary" %>
<%= link_to "My jobs", "#", class: "btn btn-lg btn-primary" %>
</div>
<h2>Edit <%= resource_name.to_s.humanize %></h2> <h1>My Page</h1>
<%= form_for(resource, as: resource_name, url: registration_path(resource_name), html: { method: :put }) do |f| %> <%= form_for(resource, as: resource_name, url: registration_path(resource_name), html: { method: :put }) do |f| %>
<%= render "users/shared/error_messages", resource: resource %> <%= render "users/shared/error_messages", resource: resource %>
<div class="form-group"> <div class="form-group">
<%= f.label :email %><br/> <%= f.label :email %><br/>
<%= f.email_field :email, autofocus: true, autocomplete: "email", class: "form-control" %> <%= f.email_field :email, autofocus: true, class: "form-control" %>
</div> </div>
<% if devise_mapping.confirmable? && resource.pending_reconfirmation? %> <% if devise_mapping.confirmable? && resource.pending_reconfirmation? %>
...@@ -22,9 +22,14 @@ ...@@ -22,9 +22,14 @@
<%= f.text_field :last_name, class: "form-control" %> <%= f.text_field :last_name, class: "form-control" %>
</div> </div>
<div class="field">
<%= f.label :cv_path %><br/>
<input type="file" class="form-control-file" id="cv_path">
</div><br>
<div class="form-group"> <div class="form-group">
<%= f.label :password %> <i>(leave blank if you don't want to change it)</i><br/> <%= f.label :password %> <i>(leave blank if you don't want to change it)</i><br/>
<%= f.password_field :password, autocomplete: "new-password", class: "form-control" %> <%= f.password_field :password, autocomplete: "off", class: "form-control" %>
<% if @minimum_password_length %> <% if @minimum_password_length %>
<br/> <br/>
<em><%= @minimum_password_length %> characters minimum</em> <em><%= @minimum_password_length %> characters minimum</em>
...@@ -33,21 +38,19 @@ ...@@ -33,21 +38,19 @@
<div class="form-group"> <div class="form-group">
<%= f.label :password_confirmation %><br/> <%= f.label :password_confirmation %><br/>
<%= f.password_field :password_confirmation, autocomplete: "new-password", class: "form-control" %> <%= f.password_field :password_confirmation, autocomplete: "off", class: "form-control" %>
</div> </div>
<div class="field"> <div class="form-group">
<%= f.label :cv_path %><br/> <%= f.label :current_password %> <i>(we need your current password to confirm your changes)</i><br />
<input type="file" class="form-control-file" id="cv_path"> <%= f.password_field :current_password, autocomplete: "off", class: "form-control" %>
</div><br> </div>
<div class="actions"> <div class="actions">
<%= f.submit "Update" %> <%= f.submit "Update", class: "btn btn-lg btn-primary" %>
</div> </div>
<% end %> <% end %>
<br>
<h3>Cancel my account</h3> <%= button_to "Delete my account", registration_path(resource_name), data: { confirm: "Are you sure?" }, class: "btn btn-danger", method: :delete %>
<p>Unhappy? <%= button_to "Cancel my account", registration_path(resource_name), data: { confirm: "Are you sure?" }, method: :delete %></p>
<%= link_to "Back", :back %> <%= link_to "Back", :back %>
...@@ -6,4 +6,5 @@ Rails.application.routes.draw do ...@@ -6,4 +6,5 @@ Rails.application.routes.draw do
devise_for :users devise_for :users
root "static_pages#index" root "static_pages#index"
get "static_pages/index" get "static_pages/index"
get "my", to: "users/my_page#index"
end end
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment