422 lines
14 KiB
Ruby
422 lines
14 KiB
Ruby
# encoding: utf-8
|
|
class Admin::NewsController < OrbitAdminController
|
|
require 'rubyXL'
|
|
include Admin::NewsHelper
|
|
before_action ->(module_app = @app_title) { set_variables module_app }
|
|
before_action :set_news_bulletin, only: [:edit, :destroy]
|
|
before_action :load_access_level
|
|
|
|
def initialize
|
|
super
|
|
@app_title = "news"
|
|
end
|
|
|
|
def index
|
|
@tags = @module_app.tags
|
|
@categories = @module_app.categories.enabled
|
|
@filter_fields = filter_fields(@categories, @tags)
|
|
@table_fields = [:status, :category, :title, :start_date, :end_date, :image, "news.unit", :view_count]
|
|
|
|
if !params[:sort].blank?
|
|
if params[:sort] == 'start_date'
|
|
sort = {:postdate=>params[:order]}
|
|
elsif params[:sort] == 'end_date'
|
|
sort = {:deadline=>params[:order]}
|
|
else
|
|
sort = {params[:sort].to_sym=>params[:order]}
|
|
end
|
|
else
|
|
sort = {:postdate=>"desc"}
|
|
end
|
|
|
|
|
|
@news_bulletin = NewsBulletin.where(:is_preview.in=>[false,nil])
|
|
.order_by(sort)
|
|
.with_categories(filters("category"))
|
|
.with_tags(filters("tag"))
|
|
.with_status(filters("status"))
|
|
|
|
@news_bulletin = search_data(@news_bulletin,[:title]).page(params[:page]).per(10)
|
|
|
|
if request.xhr?
|
|
render :partial => "index"
|
|
end
|
|
end
|
|
|
|
def new
|
|
@tags = @module_app.tags
|
|
@statuses = []
|
|
@news_bulletin = NewsBulletin.new
|
|
@news_bulletin.email_sentdate = Time.now
|
|
sort = (!params[:sort].blank? ? {params[:sort].to_sym=>params[:order]} : {:id=>"asc"})
|
|
@unit = Unit.all.order_by(sort)
|
|
end
|
|
|
|
def create
|
|
if !news_bulletin_params['news_bulletin_links_attributes'].nil?
|
|
news_bulletin_params['news_bulletin_links_attributes'].each do |idx,link|
|
|
news_bulletin_params['news_bulletin_links_attributes'].delete(idx.to_s) if link['url'].blank?
|
|
end
|
|
end
|
|
news_bulletin = NewsBulletin.new(news_bulletin_params)
|
|
news_bulletin.create_user_id = current_user.id
|
|
news_bulletin.update_user_id = current_user.id
|
|
if user_can_approve?
|
|
news_bulletin.approved = true
|
|
news_bulletin.save
|
|
else
|
|
news_bulletin.save
|
|
# Thread.new do
|
|
# begin
|
|
# send_notification_mail_to_managers(news_bulletin,"approval")
|
|
# rescue e
|
|
# end
|
|
# end
|
|
end
|
|
# build_email(news_bulletin)
|
|
redirect_to params['referer_url']
|
|
end
|
|
|
|
def approve_news_bulletin
|
|
id = params[:id]
|
|
news_bulletin = NewsBulletin.find(id)
|
|
if params["approved"] == "true"
|
|
news_bulletin.approved = true
|
|
news_bulletin.rejected = false
|
|
news_bulletin.reapproval = false
|
|
news_bulletin.save
|
|
else
|
|
news_bulletin.rejected = true
|
|
news_bulletin.reapproval = false
|
|
news_bulletin.rejection_reason = params["reason"]
|
|
news_bulletin.save
|
|
# send_rejection_email(news_bulletin)
|
|
end
|
|
redirect_to "/admin/news"
|
|
end
|
|
|
|
def edit
|
|
if can_edit_or_delete?(@news_bulletin)
|
|
sort = (!params[:sort].blank? ? {params[:sort].to_sym=>params[:order]} : {:id=>"asc"})
|
|
@unit = Unit.all.order_by(sort)
|
|
@department = Department.where(:unit_id => @news_bulletin.unit_id)
|
|
@tags = @module_app.tags
|
|
@categories = @module_app.categories.enabled
|
|
@statuses = []
|
|
@news_bulletin.email_sentdate = Time.now if @news_bulletin.email_sent == false
|
|
@selected = nil
|
|
else
|
|
render_401
|
|
end
|
|
end
|
|
|
|
def update
|
|
uid = params[:id].split('-').last
|
|
news_bulletin = NewsBulletin.where(:uid=>uid).first rescue nil
|
|
NewsBulletin.where(:copy_id=>news_bulletin.id.to_s).destroy
|
|
news_bulletin.is_edit = true
|
|
news_bulletin.save
|
|
set_approved = news_bulletin.is_preview
|
|
news_bulletin = news_bulletin.get_org_model
|
|
news_bulletin.approved = true if set_approved
|
|
news_bulletin_params[:tags] = news_bulletin_params[:tags].blank? ? [] : news_bulletin_params[:tags]
|
|
news_bulletin_params[:email_member_ids] = news_bulletin_params[:email_member_ids].blank? ? [] : news_bulletin_params[:email_member_ids]
|
|
|
|
if !news_bulletin_params['news_bulletin_links_attributes'].nil?
|
|
news_bulletin_params['news_bulletin_links_attributes'].each do |idx,link|
|
|
news_bulletin_params['news_bulletin_links_attributes'].delete(idx.to_s) if link['url'].blank?
|
|
end
|
|
end
|
|
|
|
news_bulletin.update_attributes(news_bulletin_params)
|
|
if news_bulletin.rejected
|
|
news_bulletin.reapproval = true
|
|
news_bulletin.save
|
|
# Thread.new do
|
|
# begin
|
|
# send_notification_mail_to_managers(news_bulletin, "reapproval")
|
|
# rescue e
|
|
# end
|
|
# end
|
|
end
|
|
news_bulletin.save
|
|
# build_email(news_bulletin)
|
|
redirect_to params['referer_url']
|
|
end
|
|
|
|
def destroy
|
|
@news_bulletin.destroy
|
|
redirect_to "/admin/news"
|
|
end
|
|
|
|
def delete
|
|
if params[:ids]
|
|
NewsBulletin.any_in(:uid => params[:ids]).destroy_all
|
|
end
|
|
redirect_to "/admin/news"
|
|
end
|
|
|
|
def render_404
|
|
render :file => "#{Rails.root}/app/views/errors/404.html", :layout => false, :status => 404, :formats => [:html]
|
|
end
|
|
|
|
def import_export
|
|
@thread = Multithread.where(:id=>params[:thread_id]).first if params[:thread_id].present?
|
|
end
|
|
|
|
def download_file_from_thread
|
|
@thread = Multithread.where(:id=>params[:id]).first if params[:id].present?
|
|
if @thread && @thread.status[:file]
|
|
send_file(@thread.status[:file],:filename=>@thread.status[:filename])
|
|
else
|
|
render_404
|
|
end
|
|
end
|
|
|
|
def excel_format
|
|
respond_to do |format|
|
|
format.xlsx {
|
|
response.headers['Content-Disposition'] = 'attachment; filename="news_import_format.xlsx"'
|
|
}
|
|
end
|
|
end
|
|
|
|
def export_excel
|
|
@thread = Multithread.where(:key=>'export_news').first
|
|
update_flag = true
|
|
if @thread.nil?
|
|
@thread = Multithread.create(:key=>'export_news',:status=>{:status=>'Processing'})
|
|
else
|
|
update_flag = false if @thread.status[:status] == 'Processing' && @thread.respond_to?(:updated_at) && (@thread.updated_at > DateTime.now - 1.minute rescue false)
|
|
if update_flag
|
|
@thread.update(:status=>{:status=>'Processing'})
|
|
end
|
|
end
|
|
if update_flag
|
|
@host = Site.first.root_url
|
|
if @host == "http"
|
|
@host = request.protocol + request.host_with_port
|
|
end
|
|
Thread.new do
|
|
begin
|
|
@news = NewsBulletin.where(:is_preview.ne=>true).desc(:id)
|
|
last_updated = [NewsBulletin.max(:updated_at).to_i, Unit.max(:updated_at).to_i, Department.max(:updated_at).to_i].max
|
|
filename = "public/news_export_#{last_updated}.xlsx"
|
|
if File.exist?(filename)
|
|
@thread.update(:status=>{:status=>'finish','finish_percent'=>100,'info'=>I18n.t('announcement.read_from_cache')})
|
|
else
|
|
excel_contents = render_to_string( handlers: [:axlsx], formats: [:xlsx] ,partial: 'export_excel.xlsx' )
|
|
File.open(filename, 'w') do |f|
|
|
f.write excel_contents
|
|
end
|
|
end
|
|
@thread.status[:file] = filename
|
|
@thread.status[:filename] = "news_export_#{DateTime.now.in_time_zone(Time.zone.utc_offset / 3600).strftime('%Y_%m_%d_%H%M')}.xlsx"
|
|
@thread.save
|
|
rescue => e
|
|
@thread.status[:status] = 'error'
|
|
# @thread.status[:info] = [e.to_s, e.backtrace]
|
|
puts [e.to_s, e.backtrace]
|
|
@thread.save
|
|
end
|
|
end
|
|
end
|
|
redirect_to admin_news_import_export_path(:thread_id=>@thread.id.to_s)
|
|
end
|
|
|
|
def importnews
|
|
workbook = RubyXL::Parser.parse(params["import_file"].tempfile)
|
|
raw_categories = @module_app.categories.asc(:created_at).to_a.map.with_index{|v, k| [k.to_s,v]}.to_h
|
|
raw_tags = @module_app.tags.asc(:created_at).to_a.map.with_index{|v, k| [k.to_s,v]}.to_h
|
|
categories = raw_categories.clone
|
|
tags = raw_tags.clone
|
|
sheet = workbook[0]
|
|
if sheet.count <= 503
|
|
sheet.each_with_index do |row, i|
|
|
if i == 2
|
|
begin
|
|
cats_text = row.cells[0].value.to_s.sub(/(^|,)\s*Example\s*:.*$/,'')
|
|
cats_keys = cats_text.split('->').map{|s| s.split(',')[-1].strip}[0...-1]
|
|
cats_values = cats_text.split('->')[1..-1].to_a.map{|s| s.strip.sub(/,\s*\d+$/,'')}
|
|
categories_relations = cats_keys.zip(cats_values).to_h
|
|
rescue => e
|
|
categories_relations = {}
|
|
end
|
|
begin
|
|
tags_text = row.cells[1].value.to_s.sub(/(^|,)\s*Example\s*:.*$/,'')
|
|
tags_keys = tags_text.split('->').map{|s| s.split(',')[-1].strip}[0...-1]
|
|
tags_values = tags_text.split('->')[1..-1].to_a.map{|s| s.strip.sub(/,\s*\d+$/,'')}
|
|
tags_relations = tags_keys.zip(tags_values).to_h
|
|
rescue => e
|
|
tags_relations = {}
|
|
end
|
|
if categories_relations.present?
|
|
categories = categories_relations.map do |k, v|
|
|
tmp = raw_categories[k]
|
|
if tmp && tmp.title.strip == v
|
|
[k, tmp]
|
|
else
|
|
tmp = raw_categories.detect{|kk, vv| vv.title.strip == v}
|
|
if tmp.nil?
|
|
tmp = @module_app.categories.create(:title_translations=> localize_data(v))
|
|
end
|
|
[k, tmp]
|
|
end
|
|
end.to_h
|
|
end
|
|
if tags_relations.present?
|
|
tags = tags_relations.map do |k, v|
|
|
tmp = raw_tags[k]
|
|
if tmp && tmp.name.strip == v
|
|
[k, tmp]
|
|
else
|
|
tmp = raw_tags.detect{|kk, vv| vv.name.strip == v}
|
|
if tmp.nil?
|
|
tmp = @module_app.tags.create(:name_translations=> localize_data(v))
|
|
end
|
|
[k, tmp]
|
|
end
|
|
end.to_h
|
|
end
|
|
end
|
|
next if i < 3
|
|
v = row.cells.first.value rescue nil
|
|
next if v.blank? #類別為空
|
|
import_this_news(row, categories, tags)
|
|
end
|
|
redirect_to admin_news_index_path
|
|
else
|
|
redirect_to admin_news_index_path(:error => "1")
|
|
end
|
|
end
|
|
|
|
def preview
|
|
if params['preview_type'].eql?('edit')
|
|
news_bulletin_data = news_bulletin_params
|
|
org_news_bulletin = NewsBulletin.find(params['news_bulletin_id'])
|
|
news_bulletin = org_news_bulletin.clone
|
|
news_bulletin.generate_uid
|
|
news_bulletin.news_bulletin_files = []
|
|
news_bulletin.news_bulletin_links = []
|
|
if news_bulletin_data['image'].blank?
|
|
news_bulletin.image = org_news_bulletin.image
|
|
end
|
|
|
|
if !news_bulletin_data['news_bulletin_files_attributes'].blank?
|
|
news_bulletin_data['news_bulletin_files_attributes'].each do |key, news_bulletin_file|
|
|
next if !news_bulletin_file['_destroy'].blank?
|
|
file = nil
|
|
if news_bulletin_file['id'].blank?
|
|
file = NewsBulletinFile.new(news_bulletin_file)
|
|
file.news_bulletin_id = news_bulletin.id
|
|
file.save
|
|
else
|
|
org_file = NewsBulletinFile.find(news_bulletin_file['id'])
|
|
file = org_file.clone
|
|
file.news_bulletin_id = news_bulletin.id
|
|
file.file = org_file.file
|
|
news_bulletin_file.delete('id')
|
|
news_bulletin_file.delete('_destroy')
|
|
file.update_attributes(news_bulletin_file)
|
|
end
|
|
|
|
file.save
|
|
news_bulletin.news_bulletin_files << file
|
|
end
|
|
end
|
|
|
|
if !news_bulletin_data['news_bulletin_links_attributes'].blank?
|
|
news_bulletin_data['news_bulletin_links_attributes'].each do |key, news_bulletin_link|
|
|
next if !news_bulletin_link['_destroy'].blank?
|
|
|
|
if news_bulletin_link['id'].blank?
|
|
link = NewsBulletinLink.new(news_bulletin_link)
|
|
link.news_bulletin_id = news_bulletin.id
|
|
else
|
|
link = NewsBulletinLink.find(news_bulletin_link['id']).clone
|
|
link.news_bulletin_id = news_bulletin.id
|
|
news_bulletin_link.delete('id')
|
|
news_bulletin_link.delete('_destroy')
|
|
link.update_attributes(news_bulletin_link)
|
|
end
|
|
|
|
link.save
|
|
news_bulletin.news_bulletin_links << link
|
|
end
|
|
end
|
|
|
|
news_bulletin_data.delete('news_bulletin_files_attributes')
|
|
news_bulletin_data.delete('news_bulletin_links_attributes')
|
|
news_bulletin.update_attributes(news_bulletin_data)
|
|
news_bulletin.copy_id = params['news_bulletin_id']
|
|
else
|
|
news_bulletin = NewsBulletin.new(news_bulletin_params)
|
|
end
|
|
|
|
news_bulletin.is_preview = true
|
|
news_bulletin.save
|
|
render :text=>page_for_news_bulletin(news_bulletin)
|
|
end
|
|
def get_preview_action
|
|
news_bulletin = NewsBulletin.find_by(:uid=>params['uid'])
|
|
is_not_edit = (!news_bulletin.is_edit)
|
|
org_bulletin = news_bulletin.get_org_model
|
|
NewsBulletin.where(:copy_id=>org_bulletin.id.to_s).destroy
|
|
if is_not_edit
|
|
news_bulletin.destroy
|
|
render :json=> {:success=>true,:action=>"close"}
|
|
else
|
|
render :json=> {:success=>true,:action=>"redirect",:path=>edit_admin_news_path(:id=>org_bulletin.id)}
|
|
end
|
|
end
|
|
def destroy_preview
|
|
news_bulletin = NewsBulletin.find_by(:uid=>params['uid'])
|
|
if news_bulletin.is_preview
|
|
news_bulletin.destroy
|
|
end
|
|
render :json=>{'destroy'=>news_bulletin.id.to_s}
|
|
end
|
|
|
|
def build_email(news_bulletin)
|
|
if news_bulletin.email_sent and !news_bulletin.email_addresses.blank?
|
|
if news_bulletin.email.nil?
|
|
email = Email.new
|
|
email.save
|
|
news_bulletin.email_id = email.id
|
|
news_bulletin.save
|
|
end
|
|
|
|
is_sent = news_bulletin.email.is_sent
|
|
is_sent = !params[:resend_mail].eql?("true") if !params[:resend_mail].blank?
|
|
|
|
news_bulletin.email.update_attributes(
|
|
:create_user=>current_user,
|
|
:mail_sentdate=>news_bulletin.email_sentdate,
|
|
:module_app=>@module_app,
|
|
:mail_to=>news_bulletin.email_addresses,
|
|
:mail_subject=>news_bulletin.title,
|
|
:template=>'news/email',
|
|
:template_data=>{
|
|
"host" => request.host_with_port,
|
|
"title" => news_bulletin.title,
|
|
"url" => page_for_news_bulletin(news_bulletin)
|
|
},
|
|
:is_sent=>is_sent
|
|
)
|
|
else
|
|
news_bulletin.email.destroy if !news_bulletin.email.nil?
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def set_news_bulletin
|
|
@news_bulletin = NewsBulletin.find(params[:id])
|
|
end
|
|
|
|
def news_bulletin_params
|
|
params[:news_bulletin][:email_sent] = params[:news_bulletin][:email_sent].nil? ? 0 : params[:news_bulletin][:email_sent]
|
|
params.require(:news_bulletin).permit!
|
|
end
|
|
end
|