Skip to content
Extraits de code Groupes Projets
Valider ffe48fe1 rédigé par Sarah Mei's avatar Sarah Mei
Parcourir les fichiers

Refactor aspects#index to be easier to read; move some expensive operations after the guard clause

parent ae106e71
Aucune branche associée trouvée
Aucune étiquette associée trouvée
Aucune requête de fusion associée trouvée
...@@ -12,34 +12,34 @@ class AspectsController < ApplicationController ...@@ -12,34 +12,34 @@ class AspectsController < ApplicationController
def index def index
if params[:a_ids] if params[:a_ids]
@aspects = current_user.aspects.where(:id => params[:a_ids]).includes(:contacts => {:person => :profile}) @aspects = current_user.aspects.where(:id => params[:a_ids])
else else
@aspects = current_user.aspects.includes(:contacts => {:person => :profile}) @aspects = current_user.aspects
end end
@selected_contacts = @aspects.inject([]) { |arr, aspect| arr.concat(aspect.contacts) } @aspects = @aspects.includes(:contacts => {:person => :profile})
@selected_contacts.uniq!
# redirect to signup # redirect to signup
if (current_user.getting_started == true || @aspects.blank?) && !request.format.mobile? && !request.format.js? if (current_user.getting_started == true || @aspects.blank?) && !request.format.mobile? && !request.format.js?
redirect_to getting_started_path redirect_to getting_started_path
else return
@aspect_ids = @aspects.map { |a| a.id } end
@posts = StatusMessage.joins(:aspects).where(:pending => false, @selected_contacts = @aspects.map { |aspect| aspect.contacts }.flatten.uniq
:aspects => {:id => @aspect_ids}).includes(:comments, :photos, :likes, :dislikes).select('DISTINCT `posts`.*').paginate( @aspect_ids = @aspects.map { |a| a.id }
:page => params[:page], :per_page => 15, :order => session[:sort_order] + ' DESC') @posts = StatusMessage.joins(:aspects).where(:pending => false,
@fakes = PostsFake.new(@posts) :aspects => {:id => @aspect_ids}).includes(:comments, :photos, :likes, :dislikes).select('DISTINCT `posts`.*').paginate(
:page => params[:page], :per_page => 15, :order => session[:sort_order] + ' DESC')
@fakes = PostsFake.new(@posts)
@contact_count = current_user.contacts.count @contact_count = current_user.contacts.count
@aspect = :all unless params[:a_ids] @aspect = :all unless params[:a_ids]
@aspect ||= @aspects.first #used in mobile @aspect ||= @aspects.first # used in mobile
end
end end
def create def create
@aspect = current_user.aspects.create(params[:aspect]) @aspect = current_user.aspects.create(params[:aspect])
#hack, we don't know why mass assignment is not working # hack, we don't know why mass assignment is not working
@aspect.contacts_visible = params[:aspect][:contacts_visible] @aspect.contacts_visible = params[:aspect][:contacts_visible]
@aspect.save @aspect.save
......
0% Chargement en cours ou .
You are about to add 0 people to the discussion. Proceed with caution.
Terminez d'abord l'édition de ce message.
Veuillez vous inscrire ou vous pour commenter