diff --git a/.gitignore b/.gitignore index de5d954..954abfc 100644 --- a/.gitignore +++ b/.gitignore @@ -5,4 +5,4 @@ test/dummy/db/*.sqlite3 test/dummy/db/*.sqlite3-journal test/dummy/log/*.log test/dummy/tmp/ -test/dummy/.sass-cache +test/dummy/.sass-cache \ No newline at end of file diff --git a/Gemfile b/Gemfile index f20f90b..402bb5d 100644 --- a/Gemfile +++ b/Gemfile @@ -9,6 +9,5 @@ gemspec # your gemspec. These might include edge Rails or gems from your path or # Git. Remember to move these dependencies to your gemspec before releasing # your gem to rubygems.org. - # To use debugger # gem 'debugger' diff --git a/Rakefile b/Rakefile index 7ae136a..a52bbe3 100644 --- a/Rakefile +++ b/Rakefile @@ -5,7 +5,6 @@ rescue LoadError end require 'rdoc/task' - RDoc::Task.new(:rdoc) do |rdoc| rdoc.rdoc_dir = 'rdoc' rdoc.title = 'PersonalJournal' @@ -16,7 +15,6 @@ end - Bundler::GemHelper.install_tasks require 'rake/testtask' diff --git a/app/controllers/admin/journal_papers_controller.rb b/app/controllers/admin/journal_papers_controller.rb index d8c675c..3073be8 100644 --- a/app/controllers/admin/journal_papers_controller.rb +++ b/app/controllers/admin/journal_papers_controller.rb @@ -116,7 +116,7 @@ class Admin::JournalPapersController < OrbitMemberController def destroy @journal_paper.destroy respond_to do |format| - format.html { redirect_to(admin_journal_paper_url) } + format.html { redirect_to(admin_journal_papers_url) } # format.xml { head :ok } format.js format.json {render json: {"success" => true}} diff --git a/app/controllers/personal_journals_controller.rb b/app/controllers/personal_journals_controller.rb index 326c8ab..8b3c826 100644 --- a/app/controllers/personal_journals_controller.rb +++ b/app/controllers/personal_journals_controller.rb @@ -1,57 +1,53 @@ class PersonalJournalsController < 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 - journal_papers = JournalPaper.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 + journal_papers = JournalPaper.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 = [ - "paper_title", - "journal_title", - "authors", - "year", - "issue_no", - "vol_no", - "level_type" - ] if fields_to_show.blank? + if fields_to_show.blank? + fields_to_show = %w[ + paper_title + journal_title + authors + year + issue_no + vol_no + level_type + ] + end else - fields_to_show = [ - "year", - "paper_title" + fields_to_show = %w[ + year + paper_title ] end - if params[:selectbox] !=nil - journal_papers_temp = JournalPaper.where(:is_hidden=>false).sort_by{ |tp| [-tp[:year].to_i,-tp[:publication_date].to_i] } + if !params[:selectbox].nil? + journal_papers_temp = JournalPaper.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" - journal_papers_show = journal_papers_temp.select {|value| search_all_words(value.paper_title, params[:keywords])} + when 'paper_title', 'default' + if page.custom_string_field == 'table' + journal_papers_show = journal_papers_temp.select { |value| search_all_words(value.paper_title, params[:keywords]) } else - journal_papers_show = journal_papers_temp.select {|value| search_all_words(value.create_link, params[:keywords])} + journal_papers_show = journal_papers_temp.select { |value| search_all_words(value.create_link, params[:keywords]) } end - when "level_type" - journal_papers_show = journal_papers_temp.select {|value| search_all_words(value.journal_levels.collect{|x| x.title}.join(', ').to_s, params[:keywords])} - when "publication_date" - journal_papers_show = journal_papers_temp.select {|value| search_all_words((value.send("publication_date").strftime("%Y/%m/%d") rescue ""), params[:keywords])} - when "author_type" - journal_papers_show = journal_papers_temp.select {|value| search_all_words(value.journal_paper_author_types.collect{|jat| jat.title}.join(", "), params[:keywords])} - when "language" - journal_papers_show = journal_papers_temp.select {|value| search_all_words((!value.language.nil? ? t("#{value.language}") : ""), params[:keywords])} + when 'level_type' + journal_papers_show = journal_papers_temp.select { |value| search_all_words(value.journal_levels.collect(&:title).join(', ').to_s, params[:keywords]) } + when 'publication_date' + journal_papers_show = journal_papers_temp.select { |value| search_all_words((value.send('publication_date').strftime('%Y/%m/%d') rescue ''), params[:keywords]) } + when 'author_type' + journal_papers_show = journal_papers_temp.select { |value| search_all_words(value.journal_paper_author_types.collect(&:title).join(', '), params[:keywords]) } + when 'paper_type' + journal_papers_show = journal_papers_temp.select { |value| search_all_words((value.journal_paper_type.title rescue ''), params[:keywords]) } + when 'language' + journal_papers_show = journal_papers_temp.select { |value| search_all_words((!value.language.nil? ? t(value.language.to_s) : ''), params[:keywords]) } else - journal_papers_show = journal_papers_temp.select {|value| search_all_words(value.send(params[:selectbox]).to_s, params[:keywords])} + journal_papers_show = journal_papers_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 - journal_papers = journal_papers_show[(page_to_show-1)*OrbitHelper.page_data_count...page_to_show*OrbitHelper.page_data_count] - journal_papers_total_pages = (journal_papers_show.length/OrbitHelper.page_data_count.to_f).ceil + page_to_show = params[:page_no].nil? ? 1 : params[:page_no].to_i + journal_papers = journal_papers_show[(page_to_show - 1) * page_data_count...page_to_show * page_data_count] + journal_papers_total_pages = (journal_papers_show.length / page_data_count.to_f).ceil else journal_papers_total_pages = journal_papers.total_pages end @@ -60,127 +56,137 @@ class PersonalJournalsController < ApplicationController t = [] fields_to_show.each do |fs| case fs - when "paper_title" - if page.custom_string_field == "table" - t << {"value" => "#{journal_paper.paper_title}"} + when 'paper_title' + if page.custom_string_field == 'table' + t << { 'value' => "#{journal_paper.paper_title}" } else - t << {"value" => "#{journal_paper.create_link}"} + t << { 'value' => "#{journal_paper.create_link}" } end - when "level_type" - t << {"value" => ( !journal_paper.journal_levels.blank? ? "(#{journal_paper.journal_levels.collect{|x| x.title}.join(', ')})" : nil)} - when "publication_date" - t << {"value" => (journal_paper.send(fs).strftime("%Y/%m") rescue "")} - when "author_type" - t << {"value" => (journal_paper.journal_paper_author_types.collect{|jat| jat.title}.join(", ") rescue "")} - when "language" - t << {"value" => (!journal_paper.language.nil? ? t("#{journal_paper.language}") : "")} + when 'level_type' + t << { 'value' => (!journal_paper.journal_levels.blank? ? "(#{journal_paper.journal_levels.collect(&:title).join(', ')})" : nil) } + when 'publication_date' + t << { 'value' => (journal_paper.send(fs).strftime('%Y/%m') rescue '') } + when 'author_type' + t << { 'value' => (journal_paper.journal_paper_author_types.collect(&:title).join(', ') rescue '') } + when 'paper_type' + t << { 'value' => (journal_paper.journal_paper_type.title rescue '') } + when 'language' + t << { 'value' => (!journal_paper.language.nil? ? t(journal_paper.language.to_s) : '') } else - t << {"value" => journal_paper.send(fs)} + t << { 'value' => (journal_paper.send(fs) rescue '') } end end - journal_paper_list << {"jps" => t} + journal_paper_list << { 'jps' => t } end headers = [] choice_show = [] 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_journal.#{fs}"), - "col" => col + 'head-title' => t("personal_journal.#{fs}"), + 'col' => col } choice_show << t("personal_journal.#{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_journal.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_journal.search_class') + search_text = t('personal_journal.word_to_search') { - "journal_papers" => journal_paper_list, - "headers" => headers, - "extras" => {"widget-title" => t("module_name.journal_paper"), - "url" => "/"+params[:locale]+params[:url], - "select_text" => select_text, - "search_text" => search_text, - "search_value" => params[:keywords]}, - "total_pages" => journal_papers_total_pages, - "choice" => choice + 'journal_papers' => journal_paper_list, + 'headers' => headers, + 'extras' => { 'widget-title' => t('module_name.journal_paper'), + 'url' => '/' + params[:locale] + params[:url], + 'select_text' => select_text, + 'search_text' => search_text, + 'search_value' => params[:keywords] }, + 'total_pages' => journal_papers_total_pages, + 'choice' => choice } end def show params = OrbitHelper.params - plugin = JournalPaper.where(:is_hidden=>false).find_by(uid: params[:uid]) - fields_to_show = [ - "year", - "authors", - "author_type", - "paper_title", - "journal_title", - "vol_no", - "issue_no", - "form_to_start", - "form_to_end", - "level_type", - "paper_type", - "total_pages", - "publication_date", - "isbn", - "abstract", - "language", - "url", - "associated_project", - "file" + plugin = JournalPaper.where(is_hidden: false).find_by(uid: params[:uid]) + fields_to_show = %w[ + year + authors + author_type + paper_title + journal_title + vol_no + issue_no + form_to_start + form_to_end + level_type + paper_type + total_pages + publication_date + isbn + abstract + language + url + associated_project + file ] - - {"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", - "author_type", - "paper_title", - "journal_title", - "vol_no", - "issue_no", - "form_to_start", - "form_to_end", - "level_type", - "paper_type", - "total_pages", - "publication_date", - "isbn", - "abstract", - "language", - "url" + @fields_to_show = %w[ + year + authors + author_type + paper_title + journal_title + vol_no + issue_no + form_to_start + form_to_end + level_type + paper_type + total_pages + publication_date + isbn + abstract + language + url ] - @fields_to_show = @fields_to_show.map{|fs| [t("personal_journal.#{fs}"), fs]} - @default_fields_to_show = [ - "paper_title", - "journal_title", - "authors", - "year", - "issue_no", - "vol_no", - "level_type" + @fields_to_show = @fields_to_show.map { |fs| [t("personal_journal.#{fs}"), fs] } + @default_fields_to_show = %w[ + paper_title + journal_title + authors + year + issue_no + vol_no + level_type ] - 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 diff --git a/app/models/journal_paper.rb b/app/models/journal_paper.rb index 0152181..8ff8da1 100644 --- a/app/models/journal_paper.rb +++ b/app/models/journal_paper.rb @@ -36,7 +36,7 @@ class JournalPaper has_and_belongs_to_many :journal_levels has_many :journal_paper_files, autosave: true, dependent: :destroy - accepts_nested_attributes_for :journal_paper_files + accepts_nested_attributes_for :journal_paper_files, :allow_destroy => true # has_and_belongs_to_many :journal_paper_authors, dependent: :destroy # accepts_nested_attributes_for :journal_paper_authors @@ -160,11 +160,11 @@ class JournalPaper # end # def save_journal_paper_files - # self.journal_paper_files.each do |t| - # if t.should_destroy - # t.destroy - # end - # end + # self.journal_paper_files.each do |t| + # if t.should_destroy + # t.destroy + # end + # end # end # def save_journal_paper_authors @@ -211,8 +211,8 @@ class JournalPaper files = [] self.journal_paper_files.each do |file| url = file.journal_file.url - title = (file.title.blank? ? File.basename(file.journal_file.path) : file.title) - files << "
  • #{title}
  • " + title = ((file.title.blank? ? File.basename(file.journal_file.path) : file.title) rescue "") + files << (url.nil? ? "" : "
  • #{title}
  • ") end value = files.join("") else diff --git a/app/views/admin/journal_papers/_form_file.html.erb b/app/views/admin/journal_papers/_form_file.html.erb index 7d52692..a1d8251 100644 --- a/app/views/admin/journal_papers/_form_file.html.erb +++ b/app/views/admin/journal_papers/_form_file.html.erb @@ -38,7 +38,7 @@ <%= f.hidden_field :id %> - <%= f.hidden_field :should_destroy, :value => nil, :class => 'should_destroy' %> + <%= f.hidden_field :_destroy, :value => nil, :class => 'should_destroy' %> <% end %> diff --git a/app/views/admin/journal_papers/_writing_journal.html.erb b/app/views/admin/journal_papers/_writing_journal.html.erb index b348310..0670767 100644 --- a/app/views/admin/journal_papers/_writing_journal.html.erb +++ b/app/views/admin/journal_papers/_writing_journal.html.erb @@ -2,7 +2,7 @@ <%= writing_journal.year %> - <%= link_to writing_journal.create_link, page_for_journal_paper(writing_journal), target: "blank"%> + <%= link_to writing_journal.create_link, OrbitHelper.url_to_plugin_show(writing_journal.to_param,'personal_journal').to_s, target: "blank"%>