mirror of
https://gitlink.org.cn/Gitlink/forgeplus.git
synced 2026-05-03 03:40:49 +08:00
修改个人主页
This commit is contained in:
@@ -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"
|
||||
|
||||
Reference in New Issue
Block a user