X-Git-Url: https://git.mdrn.pl/redakcja_redmine.git/blobdiff_plain/f56dbf25229ca32844499b735b623a154536dc36..2119dcd48d7637772372f542358259b0cc384e35:/lib/issue_publication_hook.rb diff --git a/lib/issue_publication_hook.rb b/lib/issue_publication_hook.rb index 77fa215..6d2101c 100644 --- a/lib/issue_publication_hook.rb +++ b/lib/issue_publication_hook.rb @@ -1,36 +1,55 @@ # Provides a link to the document on the platform class IssuesPublicationHook < Redmine::Hook::ViewListener - def view_issues_show_details_bottom(context) - # TODO: złapać wyjątek konwersji - if context[:issue].tracker_id == Setting.plugin_redmine_publications[:tracker].to_i - result = "Publication(s):" - names = context[:issue].publication_names {|name| "" + name + ""} - result << names.join(', ') - result << "" - end + def self.render_on(hook, options={}) + define_method hook do |context| + if !options.include?(:if) || evaluate_if_option(options[:if], context) + context[:controller].send(:render_to_string, {:locals => context}.merge(options)) + end + end end + private + + def evaluate_if_option(if_option, context) + case if_option + when Symbol + send(if_option, context) + when Method, Proc + if_option.call(context) + end + end + + def is_pticket?(context) + context[:issue].tracker_id == Setting.plugin_redmine_publications[:tracker].to_i + end + + public + + render_on :view_issues_show_details_bottom, :partial => 'issue_view_pub', :if => :is_pticket? + render_on :view_issues_form_details_bottom, :partial => 'issue_form_pub', :if => :is_pticket? + + # names = context[:issue].publication_names {|name| "" + name + ""} + # result << names.join(', ') + def controller_issues_edit_before_save(context) - if context[:issue].tracker.id == Setting.plugin_redmine_publications[:tracker].to_i - old_value = context[:issue].publication_names - new_value = context[:params][:publications].split(',').map { |n| n.strip } - context[:journal].details << JournalDetail.new( - :property => 'attr', :prop_key => "publications", - :old_value => old_value.join(', '), - :value => new_value.join(', ') ) unless new_value==old_value - context[:issue].publication_names = new_value - end + if is_pticket?context + old_value = context[:issue].publication_names + new_value = context[:params][:publications].split(',').map { |n| n.strip } + context[:journal].details << JournalDetail.new( + :property => 'attr', :prop_key => "publications", + :old_value => old_value.join(', '), + :value => new_value.join(', ') ) unless new_value==old_value + context[:issue].publication_names = new_value + end end def controller_issues_new_after_save(context) - if context[:issue].tracker.id == Setting.plugin_redmine_publications[:tracker].to_i - value = context[:params][:publications].split(',').map { |n| n.strip } - context[:issue].publication_names = value - context[:issue].save - end + if is_pticket?context + value = context[:params][:publications].split(',').map { |n| n.strip } + context[:issue].publication_names = value + context[:issue].save + end end - - render_on :view_issues_form_details_bottom, :partial => 'issue_form_pub' end