personal-activity/app/controllers/admin/activities_controller.rb

205 lines
5.5 KiB
Ruby

class Admin::ActivitiesController < OrbitMemberController
layout "member_plugin"
include Admin::PersonalActivitiesHelper
before_action :set_activity, only: [:show, :edit, :update, :destroy]
before_action :set_plugin
before_action :get_settings,:only => [:new, :edit, :setting]
before_action :need_access_right
before_action :allow_admin_only, :only => [:index, :setting]
def index
@activities = Activity.sort_year_date.page(params[:page]).per(10)
#respond_to do |format|
#format.html
#format.xml { render :xml => @activities }
#end
end
def new
@member = MemberProfile.find_by(:uid=>params['uid']) rescue nil
@activity = Activity.new
if params[:desktop]
render :layout => false
end
end
def create
if !activity_params['member_profile_id'].blank?
@member = MemberProfile.find(activity_params['member_profile_id']) rescue nil
@activity = Activity.new(activity_params)
@activity.save
if params[:desktop] == "true"
render json: {"data" => get_paper_list}.to_json
else
redirect_to params['referer_url']
end
elsif !params[:author_members].blank?
params[:author_members].each do |author_member|
activity_params['member_profile_id'] = author_member
@activity = Activity.new(activity_params)
@activity.save
if params[:desktop] == "true"
render json: {"data" => get_paper_list}.to_json
end
end
redirect_to params['referer_url']
else
activity_params['member_profile_id'] = User.find(current_user.id).member_profile_id
@activity = Activity.new(activity_params)
@activity.save
if params[:desktop] == "true"
render json: {"data" => get_paper_list}.to_json
end
redirect_to params['referer_url']
end
end
def edit
@member = @activity.member_profile rescue nil
if params[:desktop]
render :layout => false
end
end
def update
@member = @activity.member_profile rescue nil
@activity.update_attributes(activity_params)
@activity.save
if params[:desktop] == "true"
render json: {"data" => get_paper_list}.to_json
else
redirect_to params['referer_url']
end
end
def destroy
@activity.destroy
respond_to do |format|
format.html { redirect_to(admin_activities_url) }
format.js
format.json { render json: { "success" => true } }
end
end
def analysis
end
def analysis_report
role = params[:role_id]
year_start = params[:year_start].to_i
year_end = params[:year_end].to_i
graph_by = params[:graph_by]
@data = get_chart_data(year_start,year_end,role,params[:graph_by])
render :layout => false
end
def download_excel_format
respond_to do |format|
format.xlsx {
response.headers['Content-Disposition'] = 'attachment; filename="activities_format.xlsx"'
}
end
end
def download_excel
year_start = params[:year_start].to_i
year_end = params[:year_end].to_i
@data = get_data_for_excel(year_start,year_end)
respond_to do |format|
format.xlsx {
response.headers['Content-Disposition'] = 'attachment; filename="activities.xlsx"'
}
end
end
def import_from_excel
workbook = RubyXL::Parser.parse(params["import_file"].tempfile)
sheet = workbook[0]
if sheet.count <= 503
sheet.each_with_index do |row, i|
next if i < 3
user = User.where(:user_name => row.cells[0].value).first rescue nil
if !user.nil?
mp = user.member_profile
import_this_activity(row,mp)
end
end
redirect_to admin_activities_url
else
redirect_to admin_activities_url(:error => "1")
end
end
def toggle_hide
if params[:ids]
@activities = Activity.any_in(_id: params[:ids])
@activities.each do |activity|
activity.is_hidden = params[:disable]
activity.save
end
end
render json: {"success"=>true}
end
def setting
end
def frontend_setting
@member = MemberProfile.find_by(:uid=>params['uid']) rescue nil
@intro = ActivityIntro.find_by(:member_profile_id=>@member.id) rescue nil
@intro = @intro.nil? ? ActivityIntro.new({:member_profile_id=>@member.id}) : @intro
end
def update_frontend_setting
@member = MemberProfile.find(intro_params['member_profile_id']) rescue nil
@intro = ActivityIntro.find_by(:member_profile_id=>@member.id) rescue nil
@intro = @intro.nil? ? ActivityIntro.new({:member_profile_id=>@member.id}) : @intro
@intro.update_attributes(intro_params)
@intro.save
redirect_to URI.encode('/admin/members/'+@member.to_param+'/activity')
end
def get_settings
end
def set_plugin
@plugin = OrbitApp::Plugin::Registration.all.select{|plugin| plugin.app_name.eql? 'Activity'}.first
@module_app = ModuleApp.where(:key=>'personal_activity').first
@module_app = ModuleApp.create(:key=>'personal_activity',:title=>'PersonalActivity','frontend_enable'=>true) if @module_app.nil?
@categories = @module_app.categories
end
private
def set_activity
path = request.path.split('/')
if path.last.include? '-'
uid = path[-1].split("-").last
uid = uid.split("?").first
else
uid = path[-2].split("-").last
uid = uid.split("?").first
end
@activity = Activity.find_by(:uid => uid) rescue Activity.find(params[:id])
end
def activity_params
params.require(:activity).permit! rescue nil
end
def intro_params
params.require(:activity_intro).permit! rescue nil
end
end