hps_member/app/controllers/member_counselors_controlle...

133 lines
3.2 KiB
Ruby
Raw Normal View History

2017-05-18 12:12:35 +00:00
class MemberCounselorsController < CUserController
before_filter :is_user_authorized?, :only => ["show"]
def index
2017-05-25 16:35:05 +00:00
idx = 0
cities = HpsCity.all.collect do |city|
total = 0
idx = idx + 1
schools = city.hps_schools.collect do |school|
2017-05-25 17:19:16 +00:00
members = HpsMember.where(:hps_school_id => school.id.to_s).pluck(:id)
count = HpsFile.where(:hps_member_id.in => members).count
2017-05-25 16:35:05 +00:00
total = count + total
{
"name" => school.name,
"url_to_show" => OrbitHelper.url_to_show(school.to_param) + "?method=proposals",
"count" => count
}
end
{
"name" => city.name,
"total" => total,
"id" => "tab#{idx}",
"schools" => schools
}
end
{
"cities" => cities,
"extras" => {}
}
end
def proposals
params = OrbitHelper.params
school = HpsSchool.where(:uid => params[:uid]).first
members = HpsMember.where(:hps_school_id => school.id.to_s)
page = Page.where(:page_id => params[:page_id]).first
files = []
members.each do |member|
member.hps_files.each do |file|
files << {
"title" => file.title,
"download_count" => file.download_count,
"url" => "/cuser/download?file_id=#{file.id.to_s}"
}
end
end
{
"files" => files,
"data" => {
"back-url" => "/" + I18n.locale.to_s + page.url
}
}
end
def download
file_id = params[:file_id]
file = HpsFile.find(file_id) rescue nil
if !file.nil?
file.download_count = file.download_count + 1
file.save
redirect_to file.file.url and return
end
render :nothing => true
end
def login
2017-05-18 12:12:35 +00:00
if !current_counselor_user.nil?
redirect_to member_dash_path(current_counselor_user.account)
end
end
def logoutuser
destroy_cpanel_session
redirect_to member_login_path
end
def loginuser
user = HpsMember.where(:account => params[:username]).first rescue nil
if user.nil?
redirect_to member_login_path(:error=>"invld")
else
if user.enabled
if user.authenticate(params[:password])
create_cuser_session(user)
redirect_to member_dash_path(user.account)
else
redirect_to member_login_path(:error=>"invld")
end
else
redirect_to member_login_path(:error=>"dsbld")
end
end
end
def fileupload
@hpsfile = HpsFile.new
end
def editfileupload
@hpsfile = HpsFile.find(params[:id])
end
def file_upload
hpsfile = HpsFile.new(hps_file_params)
hpsfile.hps_member = current_counselor_user
hpsfile.save
redirect_to member_dash_path(current_counselor_user.account)
end
def update_file_upload
hpsfile = HpsFile.find(params[:id])
hpsfile.update_attributes(hps_file_params)
redirect_to member_dash_path(current_counselor_user.account)
end
def deletefileupload
hpsfile = HpsFile.find(params[:id])
hpsfile.destroy
redirect_to member_dash_path(current_counselor_user.account)
end
def show
@files = current_counselor_user.hps_files
end
private
def hps_file_params
params.require(:hps_file).permit!
end
end