personal-journal/app/helpers/admin/journal_papers_helper.rb

243 lines
7.3 KiB
Ruby
Raw Normal View History

2014-06-04 03:55:13 +00:00
module Admin::JournalPapersHelper
def get_authors_text(journal)
2021-12-16 07:23:24 +00:00
authors_text = Nokogiri::HTML(journal.authors.to_s).text
split_text = authors_text.match(/[、,,\/]/)
split_text = split_text.nil? ? '/' : split_text[0]
full_authors_names = get_member(journal).collect(&:name)
if authors_text.present?
authors_names = authors_text.split(split_text).select{|a| !(full_authors_names.include?(a.strip()))}
full_authors_names += authors_names
end
full_authors_names.join(split_text)
end
def get_authors_show(journal)
2021-12-16 07:23:24 +00:00
authors_text = Nokogiri::HTML(journal.authors.to_s).text
split_text = authors_text.match(/[、,,\/]/)
split_text = split_text.nil? ? '/' : split_text[0]
full_authors_names = []
full_authors = get_member(journal).collect{|member|
member_name = member.name
full_authors_names << member_name
"<a href='#{OrbitHelper.url_to_plugin_show(member.to_param,'member')}' title='#{member_name}'>#{member_name}</a>"
}
if authors_text.present?
authors_names = authors_text.split(split_text).select{|a| !(full_authors_names.include?(a.strip()))}
full_authors += authors_names
end
2021-12-16 07:23:24 +00:00
full_authors.join(split_text)
end
def get_member(journal)
2021-12-16 07:23:24 +00:00
Array(MemberProfile.where(:id.in=>Array(journal).collect(&:member_profile_id).flatten))
end
def get_a_tag_from_members(members)
members.collect{|member| "<a href='#{OrbitHelper.url_to_plugin_show(member.to_param,'member')}' title='#{member.name}'>#{member.name}</a>"}
end
def get_member_show(journal)
get_a_tag_from_members(get_member(journal)).join('、')
end
def get_level_type(journal)
!journal.journal_levels.blank? ? "(#{journal.journal_levels.collect(&:title).join(', ')})" : nil
end
def get_author_type(journal)
journal.journal_paper_author_types.collect(&:title).join(', ') rescue ''
end
def get_paper_type(journal)
journal.journal_paper_type.title rescue ''
end
def get_publication_date(journal)
journal.publication_date.strftime('%Y/%m/%d') rescue ''
end
def page_for_journal_paper(journal_paper_object)
2014-06-25 06:20:22 +00:00
journal_paper_page = nil
pages = Page.where(:module=>"journal_paper")
2014-06-25 06:20:22 +00:00
journal_paper_page = pages.first if journal_paper_page.nil?
request.protocol+(request.host_with_port+journal_paper_page.url+'/'+journal_paper_object.to_param).gsub('//','/') rescue "/"
2014-06-25 06:20:22 +00:00
end
2014-11-26 11:39:19 +00:00
def get_paper_list
2015-01-09 07:30:13 +00:00
user = current_user.nil? ? OrbitHelper.current_user : current_user
user_profile = user.member_profile
journals = JournalPaper.where(:member_profile_id => user_profile.id)
journals = journals.collect do |j|
files = j.journal_paper_files.collect do |jpf|
2014-11-26 11:39:19 +00:00
{
2015-01-09 07:30:13 +00:00
"title" => jpf.title,
"description" => jpf.description,
"link" => jpf.journal_file.url,
"extension" => (jpf.journal_file.url.split(".").last rescue "")
2014-11-26 11:39:19 +00:00
}
end
2015-01-09 07:30:13 +00:00
{
"id" => j.id.to_s,
"edit_url" => "/#{I18n.locale.to_s}/admin/members/#{user_profile.to_param}/journal_papers/#{j.to_param}/edit",
"delete_url" => "/#{I18n.locale.to_s}/admin/journal_papers/#{j.id.to_s}",
"paper_title" => j.paper_title,
"journal_title" => j.journal_title,
"keywords" => j.keywords,
"abstract" => j.abstract,
"files" => files
}
2014-11-26 11:39:19 +00:00
end
2015-01-09 07:30:13 +00:00
journals
end
2015-12-11 11:06:33 +00:00
def import_this_journal_paper(row,mp)
value = nil
jp = JournalPaper.new
row.cells.each_with_index do |cell,index|
next if index < 2
next if cell.nil?
val = cell.value
next if val.nil? || val == ""
case index
when 2
value = {"en" => val}
when 3
begin
2020-01-20 02:25:26 +00:00
value["zh_tw"] = val
rescue
2015-12-11 11:06:33 +00:00
value = {"zh_tw" => val}
end
jp.paper_title_translations = value
when 4
value = {"en" => val}
when 5
begin
value["zh_tw"] = val
2020-01-20 02:25:26 +00:00
rescue
2015-12-11 11:06:33 +00:00
value = {"zh_tw" => val}
end
jp.journal_title_translations = value
when 6
value = {"en" => val}
when 7
begin
value["zh_tw"] = val
2020-01-20 02:25:26 +00:00
rescue
2015-12-11 11:06:33 +00:00
value = {"zh_tw" => val}
end
jp.authors_translations = value
when 8
jp.year = val
when 9
jp.language = val
when 10
jp.vol_no = val
2020-01-20 02:25:26 +00:00
when 11
2015-12-11 11:06:33 +00:00
jp.issue_no = val
when 12
jp.form_to_start = val
when 13
jp.form_to_end = val
when 14
2015-12-11 11:06:33 +00:00
jp.total_pages = val
when 15
2015-12-11 11:36:41 +00:00
jls = JournalLevel.asc(:created_at).all.to_a
2015-12-11 11:06:33 +00:00
ts = val.to_s.split(",")
2020-01-20 02:25:26 +00:00
ts.each do |t|
2015-12-14 07:17:28 +00:00
jp.journal_level_ids << jls[t.to_i].id if t.to_s.is_i? && t.to_i < jls.count
2015-12-11 11:06:33 +00:00
end
when 16
2015-12-11 11:36:41 +00:00
jpts = JournalPaperType.asc(:created_at).all.to_a
2016-01-11 12:35:44 +00:00
jp.journal_paper_type = jpts[val.to_i] if val.to_s.is_i? && val.to_i < jpts.count
when 17
2015-12-11 11:36:41 +00:00
jpas = JournalPaperAuthorType.asc(:created_at).all.to_a
2015-12-11 11:06:33 +00:00
ts = val.to_s.split(",")
ts.each do |t|
2015-12-14 07:17:28 +00:00
jp.journal_paper_author_type_ids << jpas[t.to_i].id if t.to_s.is_i? && t.to_i < jpas.count
2015-12-11 11:06:33 +00:00
end
when 18
2015-12-11 11:06:33 +00:00
jp.number_of_authors = val
when 19
2015-12-11 11:06:33 +00:00
jp.isbn = val
when 20
2015-12-11 11:06:33 +00:00
jp.publication_date = val
when 21
2015-12-11 11:06:33 +00:00
jp.url = val
2020-01-20 02:25:26 +00:00
when 22
2015-12-11 11:06:33 +00:00
jp.keywords = val
when 23
2015-12-11 11:06:33 +00:00
jp.abstract = val
when 24
2015-12-11 11:06:33 +00:00
jp.note = val
when 25
2015-12-11 11:06:33 +00:00
jp.associated_project_translations = {"en" => val, "zh_tw" => val}
end
end
jp.member_profile = mp
jp.save
end
2016-06-01 08:04:19 +00:00
2016-06-01 11:39:51 +00:00
def get_data_for_excel(year_start,year_end)
data = []
roles = Role.where(:disabled => false, :title.ne => "", :title.ne => nil).asc(:key)
2016-06-01 11:39:51 +00:00
roles.each do |role|
d = {}
d["name"] = role.title
mps = role.member_profile_ids
d1 = DateTime.new(year_start,1,1,0,0)
2020-01-20 02:25:26 +00:00
d2 = DateTime.new(year_end,12,31,23,59)
2016-06-01 11:39:51 +00:00
d["data"] = JournalPaper.where(:publication_date.gte => d1, :publication_date.lte => d2, :member_profile_id.in => mps) rescue []
data << d
end
return data
end
2016-06-01 08:04:19 +00:00
def get_chart_data(year_start,year_end,role,type)
case type
when "paper_type"
jls = JournalPaperType.all
when "level_type"
jls = JournalLevel.all
when "author_type"
jls = JournalPaperAuthorType.all
end
finaldata = []
role = Role.find(role) rescue nil
mps = []
if !role.nil?
mps = role.member_profile_ids
end
jls.each do |jl|
data = {}
data["name"] = jl.title
data["data"] = {}
(year_start..year_end).each do |year|
d1 = DateTime.new(year,1,1,0,0)
2020-01-20 02:25:26 +00:00
d2 = DateTime.new(year,12,31,23,59)
t = jl.journal_papers.where(:publication_date.gte => d1, :publication_date.lte => d2, :member_profile_id.in => mps).count rescue 0
2016-06-01 08:04:19 +00:00
data["data"][year.to_s] = t
end
finaldata << data
end
data = {"name" => "N/A", "data" => {}}
(year_start..year_end).each do |year|
d1 = DateTime.new(year,1,1,0,0)
d2 = DateTime.new(year,12,31,23,59)
2016-06-01 08:04:19 +00:00
case type
when "paper_type"
t = JournalPaper.where(:publication_date.gte => d1, :publication_date.lte => d2, :member_profile_id.in => mps, :journal_paper_type_id => nil).count rescue 0
2016-06-01 08:04:19 +00:00
when "level_type"
t = JournalPaper.where(:publication_date.gte => d1, :publication_date.lte => d2, :member_profile_id.in => mps, :journal_level_ids => nil).count rescue 0
2016-06-01 08:04:19 +00:00
when "author_type"
t = JournalPaper.where(:publication_date.gte => d1, :publication_date.lte => d2, :member_profile_id.in => mps, :journal_paper_author_type_ids => nil).count rescue 0
2016-06-01 08:04:19 +00:00
end
2020-01-20 02:25:26 +00:00
2016-06-01 08:04:19 +00:00
data["data"][year.to_s] = t
end
finaldata << data
finaldata
end
2014-06-04 03:55:13 +00:00
end
2015-12-11 11:06:33 +00:00