backup commit smart signup form
This commit is contained in:
@@ -15,6 +15,30 @@ class NewSuppliersController < ApplicationController
|
||||
@new_supplier = NewSupplier.new(params[:new_supplier])
|
||||
@new_supplier.current_employee = current_employee
|
||||
|
||||
if @new_supplier.existing_employee?
|
||||
if @new_supplier.supplier_name.present? && @new_supplier.new_supplier_name?
|
||||
save_new_supplier
|
||||
else
|
||||
sign_in @new_supplier.employee
|
||||
if @new_supplier.employee.suppliers.size < 2
|
||||
session[:supplier_id] = @new_supplier.employee.suppliers.first.try(:id)
|
||||
else
|
||||
render "choose_supplier"
|
||||
end
|
||||
end
|
||||
else
|
||||
save_new_supplier
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
def choose_supplier
|
||||
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def save_new_supplier
|
||||
if @new_supplier.save
|
||||
sign_in @new_supplier.employee unless current_employee
|
||||
Notifier.new_supplier(@new_supplier.supplier.try(:id), @new_supplier.employee.id).deliver_later
|
||||
|
||||
@@ -9,13 +9,18 @@ class NewSupplier
|
||||
attribute :password_confirmation
|
||||
|
||||
without_current_employee = { unless: 'current_employee.present?' }
|
||||
without_employee = { unless: 'employee.present?' }
|
||||
validates :supplier_name, presence: true
|
||||
validates :email, email: without_current_employee
|
||||
validates :password, presence: without_current_employee, confirmation: without_current_employee
|
||||
validates :password, presence: without_current_employee, confirmation: without_employee
|
||||
|
||||
validate :employee_uniqueness_or_existence
|
||||
validate :supplier_name_uniqueness
|
||||
|
||||
def current_employee=(employee)
|
||||
@current_employee = @employee = employee
|
||||
end
|
||||
|
||||
def save
|
||||
if valid?
|
||||
persist!
|
||||
@@ -25,6 +30,21 @@ class NewSupplier
|
||||
end
|
||||
end
|
||||
|
||||
def existing_employee?
|
||||
return true if current_employee.present?
|
||||
return false unless email.present? and password.present?
|
||||
existing_employee = Employee.find_by_email email
|
||||
if existing_employee.valid_password?(password)
|
||||
@employee = existing_employee
|
||||
return true
|
||||
end
|
||||
false
|
||||
end
|
||||
|
||||
def new_supplier_name?
|
||||
Supplier.count_by_name(supplier_name).zero?
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def persist!
|
||||
@@ -50,6 +50,8 @@ class Supplier
|
||||
has_and_belongs_to_many :employees, storing_keys: true
|
||||
has_many :employee_shifts
|
||||
|
||||
view :by_name, key: :name
|
||||
|
||||
alias_method :non_enriced_employees, :employees
|
||||
def employees
|
||||
@cached_enriched_employees ||= non_enriced_employees.tap { |es| es.each{ |e| e.enrich_with_settings(settings_for(e) ) }}
|
||||
|
||||
@@ -0,0 +1,5 @@
|
||||
h2 Choose supplier
|
||||
ul
|
||||
- current_employee.suppliers.each do |supplier|
|
||||
li= supplier.name
|
||||
|
||||
@@ -6,3 +6,4 @@ ul.nav
|
||||
ul.nav.secondary
|
||||
- Page.menu_roots.each do |page|
|
||||
li class=active_class('pages#show', name: page.name).push(page.name) = link_to page.menu_text, go_to_page_path(page.name)
|
||||
li.hide-for-large-up class=active_class('sessions#new') = link_to 'Login', new_employee_session_path
|
||||
|
||||
Reference in New Issue
Block a user