修改个人主页

This commit is contained in:
sylor_huang@126.com
2020-06-03 18:23:53 +08:00
parent e8e3a45227
commit c977b9350c
14 changed files with 148 additions and 82 deletions

View File

@@ -1,32 +1,48 @@
class Projects::ListMyQuery < ApplicationQuery
attr_reader :params, :user
attr_reader :params, :user, :is_current_admin_user
# sort_columns :updated_on, :created_on, :forked_count, :praises_count, default_by: :updated_on, default_direction: :desc
def initialize(params,user)
def initialize(params,user,is_current_admin_user)
@params = params
@user = user
@is_current_admin_user = is_current_admin_user
end
def call
if params[:category].blank?
projects = Project.joins(:members).where(members: { user_id: user.id })
elsif params[:category].to_s == "manage"
projects = Project.where(user_id: user.id)
elsif params[:category].to_s == "watched" #我关注的
projects = Project.joins(:watchers).where("watchable_type = ? and user_id = ?", "Project", user.id)
elsif params[:category].to_s == "forked" #我fork的
fork_ids = user.fork_users.select(:id, :fork_project_id).pluck(:fork_project_id)
projects = Project.where(id: fork_ids)
else
projects = Project.where.not(user_id: user.id).joins(:members).where(members: { user_id: user.id })
end
unless params[:is_public].blank?
projects = projects.where(is_public: (params[:is_public].to_s == "publicly"))
if is_current_admin_user
projects = Project
else
projects = Project.visible
end
scope = projects.includes(:project_category,:project_score, :project_language,:owner)
if params[:category].blank?
projects = projects.joins(:members).where(members: { user_id: user.id })
elsif params[:category].to_s == "join"
projects = projects.where.not(user_id: user.id).joins(:members).where(members: { user_id: user.id })
elsif params[:category].to_s == "manage"
projects = projects.where(user_id: user.id)
elsif params[:category].to_s == "watched" #我关注的
projects = projects.where.not(user_id: user.id).joins(:watchers).where(watchers: {watchable_type: "Project", user_id: user.id})
elsif params[:category].to_s == "forked" #我fork的
fork_ids = user.fork_users.select(:id, :fork_project_id).pluck(:fork_project_id)
projects = projects.where(id: fork_ids)
elsif params[:category].to_s == "public"
projects = projects.visible.joins(:members).where(members: { user_id: user.id })
elsif params[:category].to_s == "private"
projects = projects.is_private.joins(:members).where(members: { user_id: user.id })
end
if params[:project_type].to_s === "common"
projects = projects.common
elsif params[:project_type].to_s === "mirror"
projects = projects.mirror
end
q = projects.ransack(name_or_identifier_cont: params[:search])
scope = q.result.includes(:project_category, :project_language,:owner, :repository)
sort = params[:sort_by] || "updated_on"
sort_direction = params[:sort_direction] || "desc"