2014-07-03 11:25:50 +00:00
|
|
|
class Lab
|
|
|
|
include Mongoid::Document
|
|
|
|
include Mongoid::Timestamps
|
|
|
|
include OrbitModel::Status
|
|
|
|
include Slug
|
|
|
|
|
|
|
|
belongs_to :member_profile
|
|
|
|
|
|
|
|
field :lab_title, :as=>:slug_title, localize: true
|
|
|
|
field :location, localize: true
|
|
|
|
field :participating_professor, localize: true
|
|
|
|
field :participating_student, localize: true
|
|
|
|
|
|
|
|
field :year
|
|
|
|
field :language
|
|
|
|
field :keywords
|
|
|
|
field :extension_no
|
|
|
|
field :research_direction
|
|
|
|
field :facility
|
|
|
|
field :url
|
|
|
|
field :note
|
|
|
|
field :create_user_id, :type => BSON::ObjectId
|
|
|
|
field :update_user_id, :type => BSON::ObjectId
|
|
|
|
|
|
|
|
paginates_per 10
|
|
|
|
|
|
|
|
has_many :lab_files, :autosave => true, :dependent => :destroy
|
|
|
|
accepts_nested_attributes_for :lab_files, :allow_destroy => true
|
|
|
|
|
|
|
|
before_validation :add_http
|
|
|
|
|
2015-12-02 10:29:27 +00:00
|
|
|
scope :sort_for_frontend, ->{ where(:is_hidden=>false).order_by(:year => "desc") }
|
|
|
|
|
2014-08-01 11:48:33 +00:00
|
|
|
def get_plugin_data(fields_to_show)
|
|
|
|
plugin_datas = []
|
|
|
|
fields_to_show.each do |field|
|
2014-10-03 06:13:29 +00:00
|
|
|
plugin_data = self.get_plugin_field_data(field) rescue nil
|
2014-08-01 11:48:33 +00:00
|
|
|
next if plugin_data.blank? or plugin_data['value'].blank?
|
|
|
|
plugin_datas << plugin_data
|
|
|
|
end
|
|
|
|
plugin_datas
|
|
|
|
end
|
|
|
|
|
2015-01-09 07:45:32 +00:00
|
|
|
def self.get_plugin_datas_to_member(datas)
|
|
|
|
|
|
|
|
fields_to_show = [
|
|
|
|
"year",
|
|
|
|
"lab_title",
|
|
|
|
"location"
|
|
|
|
]
|
|
|
|
|
2016-02-24 06:55:38 +00:00
|
|
|
fields_to_remove = []
|
|
|
|
|
|
|
|
pd_title = []
|
|
|
|
|
|
|
|
fields_to_show.each do |t|
|
|
|
|
if (self.fields[t].type.to_s == "String" rescue false)
|
|
|
|
fields_to_remove << t if (datas.where(t.to_sym.ne => nil).or(t.to_sym.ne => "").count == 0 rescue false)
|
|
|
|
else
|
|
|
|
fields_to_remove << t if (datas.where(t.to_sym.ne => "").count == 0 rescue false)
|
|
|
|
end
|
|
|
|
pd_title << {
|
|
|
|
"plugin_data_title" => I18n.t("personal_lab.#{t}")
|
|
|
|
} if !fields_to_remove.include?(t)
|
2015-01-09 07:45:32 +00:00
|
|
|
end
|
|
|
|
|
2016-02-24 06:55:38 +00:00
|
|
|
fields_to_show = fields_to_show - fields_to_remove
|
|
|
|
|
2015-12-02 10:29:27 +00:00
|
|
|
plugin_datas = datas.sort_for_frontend.collect do |p|
|
2015-01-09 07:45:32 +00:00
|
|
|
|
|
|
|
pd_data = []
|
|
|
|
fields_to_show.collect do |t|
|
|
|
|
if t == "lab_title"
|
2015-01-20 06:45:52 +00:00
|
|
|
pd_data << { "data_title" => "<a href='#{OrbitHelper.url_to_plugin_show(p.to_param,'personal_lab')}' target='_blank'>#{p.send(t)}" }
|
2015-01-09 07:45:32 +00:00
|
|
|
else
|
|
|
|
pd_data << { "data_title" => p.send(t) }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
{
|
|
|
|
"pd_datas" => pd_data
|
|
|
|
}
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
return [pd_title,plugin_datas]
|
|
|
|
|
|
|
|
end
|
|
|
|
|
2014-08-01 11:48:33 +00:00
|
|
|
def get_plugin_field_data(field)
|
|
|
|
case field
|
|
|
|
when "language"
|
|
|
|
value = I18n.t(self.language) rescue ""
|
|
|
|
when "file"
|
|
|
|
files = []
|
|
|
|
self.lab_files.each do |lab_file|
|
|
|
|
url = lab_file.file.url
|
|
|
|
title = (lab_file.title.blank? ? File.basename(lab_file.file.path) : lab_file.title)
|
|
|
|
files << "<li><a href='#{url}'' target='_blank'>#{title}</li>"
|
|
|
|
end
|
|
|
|
value = files.join("")
|
|
|
|
else
|
|
|
|
value = self.send(field) rescue ""
|
|
|
|
end
|
|
|
|
|
|
|
|
value = (value =~ /\A#{URI::regexp(['http', 'https'])}\z/) ? "<a href='#{value}' target='blank'>#{value}</a>" : value
|
|
|
|
|
|
|
|
{
|
|
|
|
"key"=>field,
|
|
|
|
"title_class"=>"lab-#{field.gsub('_','-')}-field",
|
|
|
|
"value_class"=>"lab-#{field.gsub('_','-')}-value",
|
|
|
|
"title"=>I18n.t('personal_lab.'+field),
|
|
|
|
"value"=>value
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
2014-07-03 11:25:50 +00:00
|
|
|
protected
|
|
|
|
|
|
|
|
def add_http
|
|
|
|
unless self.url.blank? || self.url[/^http:\/\//] || self.url[/^https:\/\//]
|
|
|
|
self.url = 'http://' + self.url
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|