Speaker profile editing
This commit is contained in:
parent
da8cd26222
commit
9cca063a1b
@ -2,4 +2,13 @@ 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
|
||||
before_filter :configure_permitted_parameters, if: :devise_controller?
|
||||
|
||||
protected
|
||||
|
||||
def configure_permitted_parameters
|
||||
devise_parameter_sanitizer.for(:account_update) do |u|
|
||||
u.permit(:email, :password, :password_confirmation, :current_password, speaker_profile_attributes: [:first_name, :last_name, :public_email, :organisation, :github, :twitter, :mobile_phone, :biography])
|
||||
end
|
||||
end
|
||||
end
|
||||
|
35
app/controllers/registrations_controller.rb
Normal file
35
app/controllers/registrations_controller.rb
Normal file
@ -0,0 +1,35 @@
|
||||
class RegistrationsController < Devise::RegistrationsController
|
||||
def edit
|
||||
resource.build_speaker_profile unless resource.speaker_profile.present?
|
||||
end
|
||||
|
||||
def update
|
||||
@user = User.find(current_user.id)
|
||||
|
||||
successfully_updated = if needs_password?(@user, params)
|
||||
@user.update_with_password(devise_parameter_sanitizer.sanitize(:account_update))
|
||||
else
|
||||
# remove the virtual current_password attribute
|
||||
# update_without_password doesn't know how to ignore it
|
||||
params[:user].delete(:current_password)
|
||||
@user.update_without_password(devise_parameter_sanitizer.sanitize(:account_update))
|
||||
end
|
||||
|
||||
if successfully_updated
|
||||
set_flash_message :notice, :updated
|
||||
# Sign in the user bypassing validation in case their password changed
|
||||
sign_in @user, :bypass => true
|
||||
redirect_to after_update_path_for(@user)
|
||||
else
|
||||
render "edit"
|
||||
end
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def needs_password?(user, params)
|
||||
user.email != params[:user][:email] ||
|
||||
params[:user][:password].present? ||
|
||||
params[:user][:password_confirmation].present?
|
||||
end
|
||||
end
|
16
app/controllers/speaker_profiles_controller.rb
Normal file
16
app/controllers/speaker_profiles_controller.rb
Normal file
@ -0,0 +1,16 @@
|
||||
class SpeakerProfilesController < ApplicationController
|
||||
before_filter :authenticate_user!
|
||||
before_action :assign_speaker_profile
|
||||
|
||||
def edit
|
||||
end
|
||||
|
||||
def update
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def assign_speaker_profile
|
||||
@speaker_profile = SpeakerProfile.find_or_initialize_by(user: current_user)
|
||||
end
|
||||
end
|
@ -7,4 +7,6 @@ class User < ActiveRecord::Base
|
||||
has_one :speaker_profile
|
||||
has_many :lectures
|
||||
has_many :workshops
|
||||
|
||||
accepts_nested_attributes_for :speaker_profile, update_only: true
|
||||
end
|
||||
|
@ -1,27 +0,0 @@
|
||||
<h2>Edit <%= resource_name.to_s.humanize %></h2>
|
||||
|
||||
<%= simple_form_for(resource, as: resource_name, url: registration_path(resource_name), html: { method: :put }) do |f| %>
|
||||
<%= f.error_notification %>
|
||||
|
||||
<div class="form-inputs">
|
||||
<%= f.input :email, required: true, autofocus: true %>
|
||||
|
||||
<% if devise_mapping.confirmable? && resource.pending_reconfirmation? %>
|
||||
<p>Currently waiting confirmation for: <%= resource.unconfirmed_email %></p>
|
||||
<% end %>
|
||||
|
||||
<%= f.input :password, autocomplete: "off", hint: "leave it blank if you don't want to change it", required: false %>
|
||||
<%= f.input :password_confirmation, required: false %>
|
||||
<%= f.input :current_password, hint: "we need your current password to confirm your changes", required: true %>
|
||||
</div>
|
||||
|
||||
<div class="form-actions">
|
||||
<%= f.button :submit, "Update" %>
|
||||
</div>
|
||||
<% end %>
|
||||
|
||||
<h3>Cancel my account</h3>
|
||||
|
||||
<p>Unhappy? <%= link_to "Cancel my account", registration_path(resource_name), data: { confirm: "Are you sure?" }, method: :delete %></p>
|
||||
|
||||
<%= link_to "Back", :back %>
|
30
app/views/devise/registrations/edit.html.slim
Normal file
30
app/views/devise/registrations/edit.html.slim
Normal file
@ -0,0 +1,30 @@
|
||||
h2.entry-title Редакция на акаунт
|
||||
|
||||
= simple_form_for(resource, as: resource_name, url: registration_path(resource_name), html: { method: :put }) do |f|
|
||||
= f.error_notification
|
||||
|
||||
.form-inputs
|
||||
h3 Данни за вход в системата
|
||||
= f.input :email, required: true, autofocus: true
|
||||
|
||||
- if devise_mapping.confirmable? && resource.pending_reconfirmation?
|
||||
p Currently waiting confirmation for: #{resource.unconfirmed_email}
|
||||
|
||||
= f.input :password, autocomplete: "off", hint: "leave it blank if you don't want to change it", required: false
|
||||
= f.input :password_confirmation, required: false
|
||||
= f.input :current_password, hint: "we need your current password to confirm your changes", required: true
|
||||
|
||||
.form_inputs
|
||||
h3 Лекторски профил
|
||||
= f.simple_fields_for :speaker_profile do |ff|
|
||||
= ff.input :first_name
|
||||
= ff.input :last_name
|
||||
= ff.input :public_email
|
||||
= ff.input :organisation
|
||||
= ff.input :github
|
||||
= ff.input :twitter
|
||||
= ff.input :mobile_phone, input_html: {value: resource.speaker_profile.mobile_phone.try(:phony_formatted, format: :international)}
|
||||
= ff.input :biography
|
||||
|
||||
.form-actions
|
||||
= f.button :submit, 'Обнови'
|
14
app/views/speaker_profiles/_form.html.slim
Normal file
14
app/views/speaker_profiles/_form.html.slim
Normal file
@ -0,0 +1,14 @@
|
||||
== simple_form_for @speaker_profile do |form|
|
||||
p
|
||||
= form.error_notification
|
||||
|
||||
.form-inputs
|
||||
= form.input :first_name, autofocus: true
|
||||
= form.input :last_name
|
||||
= form.input :public_email
|
||||
= form.input :organisation
|
||||
= form.input :github
|
||||
= form.input :twitter
|
||||
= form.input :mobile_phone
|
||||
= form.input :biography
|
||||
= form.button :submit
|
3
app/views/speaker_profiles/edit.html.slim
Normal file
3
app/views/speaker_profiles/edit.html.slim
Normal file
@ -0,0 +1,3 @@
|
||||
h1.entry-title Редакция на лекторски профил
|
||||
|
||||
== render 'form'
|
@ -38,6 +38,15 @@ bg:
|
||||
password: Парола
|
||||
password_confirmation: Отново паролата
|
||||
remember_me: Запомни ме
|
||||
speaker_profile:
|
||||
first_name: Име
|
||||
last_name: Фамилия
|
||||
organisation: Организация
|
||||
public_email: Публичен email
|
||||
mobile_phone: Мобилен телефон
|
||||
biography: Биография
|
||||
github: Github акаунт
|
||||
twitter: Twitter акаунт
|
||||
lecture:
|
||||
title: Заглавие
|
||||
subtitle: Подзаглавие
|
||||
|
@ -12,6 +12,15 @@ bg:
|
||||
email: Имейл адресът Ви. Ще бъде видим само от организаторите.
|
||||
password: Парола с дължина между 8 и 128 символа
|
||||
password_confirmation: Отново въведената отгоре парола
|
||||
speaker_profile:
|
||||
first_name: Малкото Ви име
|
||||
last_name: Фамилното Ви име
|
||||
organisation: Организацията, която представлявате
|
||||
public_email: E-mail адрес, който ще бъде видим за посетителите
|
||||
mobile_phone: Мобилен телефон, който ще бъде видим само за организаторите
|
||||
biography: Опишете се с няколко изречения в трето лице :).
|
||||
github: Github акаунтът Ви
|
||||
twitter: Twitter акаунтът Ви
|
||||
lecture:
|
||||
title: Заглавието на лекцията Ви
|
||||
subtitle: Подзаглавието на лекцията Ви (ако има такова)
|
||||
@ -29,4 +38,7 @@ bg:
|
||||
language: Език, на който ще бъде воден уъркшопа
|
||||
abstract: Резюме на уъркшопа, което да може да бъде прочетено от посетителите
|
||||
description: Подробно описание на уъркшопа, което да бъде използвано от организаторския екип
|
||||
notes: Забележки, които искате да споделите с организаторския екип
|
||||
notes: Забележки, които искате да споделите с организаторския екип
|
||||
labels:
|
||||
user:
|
||||
a: b
|
@ -2,7 +2,11 @@ Rails.application.routes.draw do
|
||||
resources :lectures, only: [:index, :new, :create, :edit, :update, :show]
|
||||
resources :workshops, only: [:index, :new, :create, :edit, :update, :show]
|
||||
|
||||
devise_for :users
|
||||
devise_for :users, controllers: {registrations: 'registrations'}
|
||||
|
||||
resource :user, only: [] do
|
||||
resource :speaker_profile, only: [:edit, :update]
|
||||
end
|
||||
|
||||
root 'home#index'
|
||||
# The priority is based upon order of creation: first created -> highest priority.
|
||||
|
@ -1,15 +1,15 @@
|
||||
class CreateSpeakerProfiles < ActiveRecord::Migration
|
||||
def change
|
||||
create_table :speaker_profiles do |t|
|
||||
t.string :first_name, null: false
|
||||
t.string :last_name, null: false
|
||||
t.string :first_name
|
||||
t.string :last_name
|
||||
t.string :organisation
|
||||
t.string :public_email
|
||||
t.string :photo_url, null: false
|
||||
t.string :mobile_phone, null: false
|
||||
t.text :biography, null: false
|
||||
t.string :github, null: false
|
||||
t.string :twitter, null: false
|
||||
t.string :photo_url
|
||||
t.string :mobile_phone
|
||||
t.text :biography
|
||||
t.string :github
|
||||
t.string :twitter
|
||||
|
||||
t.timestamps
|
||||
end
|
||||
|
Loading…
Reference in New Issue
Block a user