diff --git a/app/controllers/personal_conferences_controller.rb b/app/controllers/personal_conferences_controller.rb index 362dacd..c320afc 100644 --- a/app/controllers/personal_conferences_controller.rb +++ b/app/controllers/personal_conferences_controller.rb @@ -1,60 +1,54 @@ class PersonalConferencesController < ApplicationController - def search_all_words(target,word) - target=target.upcase - words=word.upcase.split(' ') - return words.select{|value| target.include? value}==words - end def index params = OrbitHelper.params - writing_conferences = WritingConference.where(:is_hidden=>false).sort_for_frontend.page(OrbitHelper.params[:page_no]).per(OrbitHelper.page_data_count) - page = Page.where(:page_id => params[:page_id]).first rescue nil - if page.custom_string_field == "table" + page_data_count = OrbitHelper.page_data_count + writing_conferences = WritingConference.where(is_hidden: false).sort_for_frontend.page(OrbitHelper.params[:page_no]).per(page_data_count) + page = Page.where(page_id: params[:page_id]).first rescue nil + if page.custom_string_field == 'table' fields_to_show = page.custom_array_field rescue [] - fields_to_show = [ - "authors", - "paper_title", - "conference_title", - "location", - "paper_types", - "paper_levels" - ] if fields_to_show.blank? + if fields_to_show.blank? + fields_to_show = %w[ + authors + paper_title + conference_title + location + paper_types + paper_levels + ] + end else - fields_to_show = [ - "year", - "paper_title" + fields_to_show = %w[ + year + paper_title ] end - if params[:selectbox] !=nil - writing_conferences_temp = WritingConference.where(:is_hidden=>false).sort_by{ |tp| [-tp[:year].to_i,-tp[:publication_date].to_i] } + if !params[:selectbox].nil? + writing_conferences_temp = WritingConference.where(is_hidden: false).sort_by { |tp| [-tp[:year].to_i, -tp[:publication_date].to_i] } case params[:selectbox] - when "paper_title","default" - if page.custom_string_field == "table" - writing_conferences_show = writing_conferences_temp.select {|value| search_all_words(value.paper_title, params[:keywords])} + when 'paper_title', 'default' + if page.custom_string_field == 'table' + writing_conferences_show = writing_conferences_temp.select { |value| search_all_words(value.paper_title, params[:keywords]) } else - writing_conferences_show = writing_conferences_temp.select {|value| search_all_words(value.create_link, params[:keywords])} + writing_conferences_show = writing_conferences_temp.select { |value| search_all_words(value.create_link, params[:keywords]) } end - when "paper_levels" - writing_conferences_show = writing_conferences_temp.select {|value| search_all_words(value.conference_paper_levels.collect{|x| x.title}.join(', ').to_s, params[:keywords])} - when "paper_types" - writing_conferences_show = writing_conferences_temp.select {|value| search_all_words(value.conference_paper_types.collect{|x| x.title}.join(', ').to_s, params[:keywords])} - when "period" - writing_conferences_show = writing_conferences_temp.select {|value| search_all_words(value.duration, params[:keywords])} - when "publication_date" - writing_conferences_show = writing_conferences_temp.select {|value| search_all_words((value.send("publication_date").strftime("%Y/%m/%d") rescue ""), params[:keywords])} - when "author_type" - writing_conferences_show = writing_conferences_temp.select {|value| search_all_words(value.conference_author_types.collect{|cat| cat.title}.join(", "), params[:keywords])} - when "language" - writing_conferences_show = writing_conferences_temp.select {|value| search_all_words((!value.language.nil? ? t("#{value.language}") : ""), params[:keywords])} + when 'paper_levels' + writing_conferences_show = writing_conferences_temp.select { |value| search_all_words(value.conference_paper_levels.collect(&:title).join(', ').to_s, params[:keywords]) } + when 'paper_types' + writing_conferences_show = writing_conferences_temp.select { |value| search_all_words(value.conference_paper_types.collect(&:title).join(', ').to_s, params[:keywords]) } + when 'period' + writing_conferences_show = writing_conferences_temp.select { |value| search_all_words(value.duration, params[:keywords]) } + when 'publication_date' + writing_conferences_show = writing_conferences_temp.select { |value| search_all_words((value.send('publication_date').strftime('%Y/%m/%d') rescue ''), params[:keywords]) } + when 'author_type' + writing_conferences_show = writing_conferences_temp.select { |value| search_all_words(value.conference_author_types.collect(&:title).join(', '), params[:keywords]) } + when 'language' + writing_conferences_show = writing_conferences_temp.select { |value| search_all_words((!value.language.nil? ? t(value.language.to_s) : ''), params[:keywords]) } else - writing_conferences_show = writing_conferences_temp.select {|value| search_all_words(value.send(params[:selectbox]).to_s, params[:keywords])} + writing_conferences_show = writing_conferences_temp.select { |value| search_all_words(value.send(params[:selectbox]).to_s, params[:keywords]) } end - if params[:page_no].nil? - page_to_show = 1 - else - page_to_show = params[:page_no].to_i - end - writing_conferences = writing_conferences_show[(page_to_show-1)*OrbitHelper.page_data_count...page_to_show*OrbitHelper.page_data_count] - writing_conferences_total_pages = (writing_conferences_show.length/OrbitHelper.page_data_count.to_f).ceil + page_to_show = params[:page_no].nil? ? 1 : params[:page_no].to_i + writing_conferences = writing_conferences_show[(page_to_show - 1) * page_data_count...page_to_show * page_data_count] + writing_conferences_total_pages = (writing_conferences_show.length / page_data_count.to_f).ceil else writing_conferences_total_pages = writing_conferences.total_pages end @@ -63,135 +57,142 @@ class PersonalConferencesController < ApplicationController t = [] fields_to_show.each do |fs| case fs - when "paper_title" - if page.custom_string_field == "table" - t << {"value" => "#{writing_conference.paper_title}"} + when 'paper_title' + if page.custom_string_field == 'table' + t << { 'value' => "#{writing_conference.paper_title}" } else - t << {"value" => "#{writing_conference.create_link}"} + t << { 'value' => "#{writing_conference.create_link}" } end - when "paper_levels" - t << {"value" => ( !writing_conference.conference_paper_levels.blank? ? "(#{writing_conference.conference_paper_levels.collect{|x| x.title}.join(', ')})" : nil)} - when "paper_types" - t << {"value" => ( !writing_conference.conference_paper_types.blank? ? "(#{writing_conference.conference_paper_types.collect{|x| x.title}.join(', ')})" : nil)} - when "publication_date" - t << {"value" => (writing_conference.send(fs).strftime("%Y/%m") rescue "")} - when "author_type" - t << {"value" => (writing_conference.conference_author_types.collect{|cat| cat.title}.join(", ") rescue "")} - when "period" - t << {"value" => writing_conference.duration} - when "language" - t << {"value" => (!writing_conference.language.nil? ? t("#{writing_conference.language}") : "")} + when 'paper_levels' + t << { 'value' => (!writing_conference.conference_paper_levels.blank? ? "(#{writing_conference.conference_paper_levels.collect(&:title).join(', ')})" : nil) } + when 'paper_types' + t << { 'value' => (!writing_conference.conference_paper_types.blank? ? "(#{writing_conference.conference_paper_types.collect(&:title).join(', ')})" : nil) } + when 'publication_date' + t << { 'value' => (writing_conference.send(fs).strftime('%Y/%m') rescue '') } + when 'author_type' + t << { 'value' => (writing_conference.conference_author_types.collect(&:title).join(', ') rescue '') } + when 'period' + t << { 'value' => writing_conference.duration } + when 'language' + t << { 'value' => (!writing_conference.language.nil? ? t(writing_conference.language.to_s) : '') } else - t << {"value" => writing_conference.send(fs)} + t << { 'value' => writing_conference.send(fs) } end end - writing_conference_list << {"cps" => t} + writing_conference_list << { 'cps' => t } end choice_show = [] headers = [] fields_to_show.each do |fs| col = 2 - col = 3 if fs == "paper_title" + col = 3 if fs == 'paper_title' headers << { - "head-title" => t("personal_conference.#{fs}"), - "col" => col + 'head-title' => t("personal_conference.#{fs}"), + 'col' => col } choice_show << t("personal_conference.#{fs}") end choice_value = fields_to_show - choice_value.unshift("default") - choice_select=choice_value.map{|iter| iter==params[:selectbox] ? "selected" : ""} - choice_select=choice_select.map{|value| {"choice_select" => value}} - choice_value=choice_value.map{|value| {"choice_value" => value}} - choice_default = params[:locale]!='en' ? "——選取分類——" : "——select class——" + choice_value.unshift('default') + choice_select = choice_value.map { |iter| iter == params[:selectbox] ? 'selected' : '' } + choice_select = choice_select.map { |value| { 'choice_select' => value } } + choice_value = choice_value.map { |value| { 'choice_value' => value } } + choice_default = t('personal_conference.select_class') choice_show.unshift(choice_default) - choice_show=choice_show.map{|value| {"choice_show" => value}} - choice=choice_value.zip(choice_show,choice_select) - choice=choice.map{|value| value.inject:merge} - select_text = params[:locale]!='en' ? "搜尋類別:" : "search class:" - search_text = params[:locale]!='en' ? "關鍵字搜尋:" : "word to search:" + choice_show = choice_show.map { |value| { 'choice_show' => value } } + choice = choice_value.zip(choice_show, choice_select) + choice = choice.map { |value| value.inject :merge } + select_text = t('personal_conference.search_class') + search_text = t('personal_conference.word_to_search') { - "writing_conferences" => writing_conference_list, - "extras" => { "widget-title" => t("module_name.personal_conference"), - "url" => "/"+params[:locale]+params[:url], - "select_text" => select_text, - "search_text" => search_text, - "search_value" => params[:keywords] }, - "headers" => headers, - "total_pages" => writing_conferences_total_pages, - "choice" => choice + 'writing_conferences' => writing_conference_list, + 'extras' => { 'widget-title' => t('module_name.personal_conference'), + 'url' => '/' + params[:locale] + params[:url], + 'select_text' => select_text, + 'search_text' => search_text, + 'search_value' => params[:keywords] }, + 'headers' => headers, + 'total_pages' => writing_conferences_total_pages, + 'choice' => choice } end def show params = OrbitHelper.params - plugin = WritingConference.where(:is_hidden=>false).find_by(uid: params[:uid]) - - fields_to_show = [ - "year", - "authors", - "paper_title", - "conference_title", - "location", - "period_start_date", - "period_end_date", - "period", - "paper_type", - "paper_level", - "sponsor", - "author_type", - "number_of_authors", - "abstract", - "url", - "file", - "publication_date", - "isbn", - "isi_number" , - "language" + plugin = WritingConference.where(is_hidden: false).find_by(uid: params[:uid]) + fields_to_show = %w[ + year + authors + paper_title + conference_title + location + period_start_date + period_end_date + period + paper_type + paper_level + sponsor + author_type + number_of_authors + abstract + url + file + publication_date + isbn + isi_number + language ] - - {"plugin_datas"=>plugin.get_plugin_data(fields_to_show)} + + { 'plugin_datas' => plugin.get_plugin_data(fields_to_show) } end def get_fields_for_index @page = Page.find(params[:page_id]) rescue nil - @fields_to_show = [ - "year", - "authors", - "paper_title", - "conference_title", - "location", - "period_start_date", - "period_end_date", - "period", - "paper_type", - "paper_level", - "sponsor", - "author_type", - "number_of_authors", - "abstract", - "url", - "publication_date", - "isbn", - "isi_number" , - "language" + @fields_to_show = %w[ + year + authors + paper_title + conference_title + location + period_start_date + period_end_date + period + paper_type + paper_level + sponsor + author_type + number_of_authors + abstract + url + publication_date + isbn + isi_number + language ] - @fields_to_show = @fields_to_show.map{|fs| [t("personal_conference.#{fs}"), fs] } - @default_fields_to_show = [ - "authors", - "paper_title", - "conference_title", - "location", - "paper_types", - "paper_levels" + @fields_to_show = @fields_to_show.map { |fs| [t("personal_conference.#{fs}"), fs] } + @default_fields_to_show = %w[ + authors + paper_title + conference_title + location + paper_types + paper_levels ] - render :layout => false + render layout: false end def save_index_fields page = Page.find(params[:page_id]) rescue nil page.custom_array_field = params[:keys] page.save - render :json => {"success" => true}.to_json + render json: { 'success' => true }.to_json + end + + private + + def search_all_words(target, word) + target = target.upcase + words = word.upcase.split(' ') + words.select { |value| target.include? value } == words end end \ No newline at end of file diff --git a/app/models/writing_conference.rb b/app/models/writing_conference.rb index 025425f..e700cff 100644 --- a/app/models/writing_conference.rb +++ b/app/models/writing_conference.rb @@ -192,8 +192,8 @@ class WritingConference files = [] self.writing_conference_files.each do |conference_files| url = conference_files.file.url - title = (conference_files.title.blank? ? File.basename(conference_files.file.path) : conference_files.title) - files << "
  • #{title}
  • " + title = ((conference_files.title.blank? ? File.basename(conference_files.file.path) : conference_files.title) rescue "") + files << (url.nil? ? "" : "
  • #{title}
  • ") end value = files.join("") else diff --git a/config/locales/en.yml b/config/locales/en.yml index 196285b..9e8fa4a 100644 --- a/config/locales/en.yml +++ b/config/locales/en.yml @@ -4,6 +4,9 @@ en: personal_conference: Conference Paper personal_conference: + select_class: "——select class——" + search_class: "search class:" + word_to_search: "word to search:" year : "Year" language : "Language" paper_title : "Paper Title" diff --git a/config/locales/zh_tw.yml b/config/locales/zh_tw.yml index 9a1e340..27c7b18 100644 --- a/config/locales/zh_tw.yml +++ b/config/locales/zh_tw.yml @@ -3,6 +3,9 @@ zh_tw: module_name: personal_conference: 研討會論文 personal_conference: + select_class: "——選取分類——" + search_class: "搜尋類別:" + word_to_search: "關鍵字搜尋:" year : "年度" language : "語言" paper_title : "論文名稱" diff --git a/modules/.gitkeep b/modules/.gitkeep new file mode 100644 index 0000000..e69de29 diff --git a/modules/personal_conference/.gitkeep b/modules/personal_conference/.gitkeep new file mode 100644 index 0000000..e69de29 diff --git a/modules/personal_conference/index.html.erb b/modules/personal_conference/index.html.erb new file mode 100644 index 0000000..c9a9b97 --- /dev/null +++ b/modules/personal_conference/index.html.erb @@ -0,0 +1,14 @@ + + + + + + + + + + + + +

    {{widget-title}}

    {{head-title}}
    {{value}}
    +{{pagination_goes_here}} \ No newline at end of file diff --git a/modules/personal_conference/index_search1.html.erb b/modules/personal_conference/index_search1.html.erb new file mode 100644 index 0000000..cb30bfb --- /dev/null +++ b/modules/personal_conference/index_search1.html.erb @@ -0,0 +1,37 @@ + +

    {{widget-title}}

    +
    +
    + {{select_text}} + + {{search_text}} + + + Clear +
    +
    + + + + + + + + + + + +
    {{head-title}}
    {{value}}
    +{{pagination_goes_here}} \ No newline at end of file diff --git a/modules/personal_conference/info.json b/modules/personal_conference/info.json new file mode 100644 index 0000000..bdb0c2c --- /dev/null +++ b/modules/personal_conference/info.json @@ -0,0 +1,20 @@ +{ + "frontend": [ + { + "filename" : "index", + "name" : { + "zh_tw" : "1. 列表", + "en" : "1. List" + }, + "thumbnail" : "thumb.png" + }, + { + "filename" : "index_search1", + "name" : { + "zh_tw" : "2. 列表(含搜尋)", + "en" : "2. List which includes search" + }, + "thumbnail" : "thumb.png" + } + ] +} \ No newline at end of file diff --git a/modules/personal_conference/show.html.erb b/modules/personal_conference/show.html.erb new file mode 100644 index 0000000..b183818 --- /dev/null +++ b/modules/personal_conference/show.html.erb @@ -0,0 +1,8 @@ + + + + + + + +
    {{title}}{{value}}
    diff --git a/modules/personal_conference/thumbs/.gitkeep b/modules/personal_conference/thumbs/.gitkeep new file mode 100644 index 0000000..e69de29 diff --git a/modules/personal_conference/thumbs/thumb.png b/modules/personal_conference/thumbs/thumb.png new file mode 100644 index 0000000..266af56 Binary files /dev/null and b/modules/personal_conference/thumbs/thumb.png differ diff --git a/personal_conference.gemspec b/personal_conference.gemspec index dae5f73..2c2ad75 100644 --- a/personal_conference.gemspec +++ b/personal_conference.gemspec @@ -2,7 +2,20 @@ $:.push File.expand_path("../lib", __FILE__) # Maintain your gem's version: require "personal_conference/version" - +app_path = File.expand_path(__dir__) +template_path = ENV['PWD'] + '/app/templates' +all_template = Dir.glob(template_path+'/*/') +puts 'copying module' +all_template.each do |folder| + if folder.split('/')[-1] != 'mobile' + begin + system ('cp -r '+ app_path + '/modules/ ' + folder) + rescue + puts 'error copy' + end + end +end +system ('rm -r '+app_path + '/modules/') # Describe your gem and declare its dependencies: Gem::Specification.new do |s| s.name = "personal_conference"