2020-03-19 09:13:01 +00:00
|
|
|
class Admin::WritingsController < OrbitMemberController
|
|
|
|
include Admin::PersonalWritingsHelper
|
|
|
|
layout "member_plugin"
|
|
|
|
|
|
|
|
before_action :set_writing, 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
|
2020-03-20 04:02:15 +00:00
|
|
|
@filter = params[:filter]
|
|
|
|
@mq = params[:mq]
|
|
|
|
@new_filter = params[:new_filter]
|
|
|
|
@filter = {} if @filter.nil?
|
|
|
|
@filter['category'] = [] if @filter['category'].nil?
|
|
|
|
if @new_filter.present?
|
|
|
|
if @filter['category'].include? @new_filter[:id]
|
|
|
|
@filter['category'].delete(@new_filter[:id])
|
|
|
|
else
|
|
|
|
@filter['category'] << @new_filter[:id]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
if params[:clear] != 'true'
|
|
|
|
if(params[:new_filter] != nil && params[:new_filter][:type] == 'category')
|
2022-07-26 11:14:47 +00:00
|
|
|
@writings = Writing.where(:category_id.in=> @filter['category']).sort_year_month.page(params[:page]).per(10)
|
2020-03-20 04:02:15 +00:00
|
|
|
else
|
2022-07-26 11:14:47 +00:00
|
|
|
@writings = Writing.sort_year_month.page(params[:page]).per(10)
|
2020-03-20 04:02:15 +00:00
|
|
|
end
|
|
|
|
else
|
|
|
|
redirect_to admin_writings_url
|
|
|
|
end
|
2020-03-19 09:13:01 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
def new
|
|
|
|
@member = MemberProfile.find_by(:uid=>params['uid']) rescue nil
|
|
|
|
@writing = Writing.new
|
|
|
|
if params[:desktop]
|
|
|
|
render :layout => false
|
|
|
|
end
|
|
|
|
end
|
2020-03-19 15:39:28 +00:00
|
|
|
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]
|
2020-03-19 09:13:01 +00:00
|
|
|
|
2020-03-19 15:39:28 +00:00
|
|
|
@data = get_chart_data(year_start,year_end,role,params[:graph_by])
|
|
|
|
|
|
|
|
render :layout => false
|
|
|
|
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="writings.xlsx"'
|
|
|
|
}
|
|
|
|
end
|
|
|
|
end
|
2020-03-19 09:13:01 +00:00
|
|
|
def create
|
|
|
|
|
|
|
|
if !writing_params['member_profile_id'].blank?
|
|
|
|
|
|
|
|
@member = MemberProfile.find(writing_params['member_profile_id']) rescue nil
|
|
|
|
@writing = Writing.new(writing_params)
|
|
|
|
@writing.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|
|
|
|
|
|
|
|
|
writing_params['member_profile_id'] = author_member
|
|
|
|
@writing = Writing.new(writing_params)
|
|
|
|
@writing.save
|
|
|
|
|
|
|
|
if params[:desktop] == "true"
|
|
|
|
render json: {"data" => get_paper_list}.to_json
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
redirect_to params['referer_url']
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
writing_params['member_profile_id'] = User.find(current_user.id).member_profile_id
|
|
|
|
|
|
|
|
@writing = Writing.new(writing_params)
|
|
|
|
@writing.save
|
|
|
|
|
|
|
|
if params[:desktop] == "true"
|
|
|
|
render json: {"data" => get_paper_list}.to_json
|
|
|
|
end
|
|
|
|
|
|
|
|
redirect_to params['referer_url']
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
def edit
|
|
|
|
@member = @writing.member_profile rescue nil
|
|
|
|
if params[:desktop]
|
|
|
|
render :layout => false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def update
|
|
|
|
@member = @writing.member_profile rescue nil
|
|
|
|
@writing.update_attributes(writing_params)
|
|
|
|
@writing.save
|
|
|
|
if params[:desktop] == "true"
|
|
|
|
render json: {"data" => get_paper_list}.to_json
|
|
|
|
else
|
|
|
|
redirect_to params['referer_url']
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def destroy
|
|
|
|
@writing.destroy
|
|
|
|
respond_to do |format|
|
|
|
|
format.html { redirect_to(admin_writings_url) }
|
|
|
|
# format.xml { head :ok }
|
|
|
|
format.js
|
|
|
|
format.json {render json: {"success" => true}}
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def excel_format
|
|
|
|
respond_to do |format|
|
|
|
|
format.xlsx {
|
|
|
|
response.headers['Content-Disposition'] = 'attachment; filename="writings_format.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_writing(row,mp)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
redirect_to admin_writings_url
|
|
|
|
else
|
|
|
|
redirect_to admin_writings_url(:error => "1")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
def toggle_hide
|
|
|
|
if params[:ids]
|
|
|
|
@writings = Writing.any_in(_id: params[:ids])
|
|
|
|
|
|
|
|
@writings.each do |writing|
|
|
|
|
writing.is_hidden = params[:disable]
|
|
|
|
writing.save
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
render json: {"success"=>true}
|
|
|
|
end
|
|
|
|
|
|
|
|
def setting
|
|
|
|
end
|
|
|
|
|
|
|
|
def frontend_setting
|
|
|
|
@member = MemberProfile.find_by(:uid=>params['uid']) rescue nil
|
|
|
|
@intro = WritingIntro.find_by(:member_profile_id=>@member.id) rescue nil
|
|
|
|
@intro = @intro.nil? ? WritingIntro.new({:member_profile_id=>@member.id}) : @intro
|
|
|
|
end
|
|
|
|
|
|
|
|
def update_frontend_setting
|
|
|
|
@member = MemberProfile.find(intro_params['member_profile_id']) rescue nil
|
|
|
|
@intro = WritingIntro.find_by(:member_profile_id=>@member.id) rescue nil
|
|
|
|
@intro = @intro.nil? ? WritingIntro.new({:member_profile_id=>@member.id}) : @intro
|
|
|
|
@intro.update_attributes(intro_params)
|
|
|
|
@intro.save
|
|
|
|
redirect_to URI.encode('/admin/members/'+@member.to_param+'/writing')
|
|
|
|
end
|
|
|
|
|
|
|
|
def get_settings
|
|
|
|
end
|
|
|
|
|
|
|
|
def set_plugin
|
|
|
|
@plugin = OrbitApp::Plugin::Registration.all.select{|plugin| plugin.app_name.eql? 'Writing'}.first
|
2020-03-20 04:02:15 +00:00
|
|
|
@module_app = ModuleApp.where(:key=>'personal_writing').first
|
|
|
|
@module_app = ModuleApp.create(:key=>'personal_writing',:title=>'PersonalWriting','frontend_enable'=>true) if @module_app.nil?
|
|
|
|
@categories = @module_app.categories
|
2020-03-19 09:13:01 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def set_writing
|
|
|
|
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
|
|
|
|
@writing = Writing.find_by(:uid => uid) rescue Writing.find(params[:id])
|
|
|
|
end
|
|
|
|
|
|
|
|
def writing_params
|
|
|
|
params.require(:writing).permit! rescue nil
|
|
|
|
end
|
|
|
|
|
|
|
|
def intro_params
|
|
|
|
params.require(:writing_intro).permit! rescue nil
|
|
|
|
end
|
|
|
|
end
|