end
end
@editable = editable?
- @sections_editable = @editable && User.current.allowed_to?(:edit_wiki_pages, @page.project) && params[:version].nil?
+ @sections_editable = @editable && User.current.allowed_to?(:edit_wiki_pages, @page.project) &&
+ params[:version].nil? &&
+ Redmine::WikiFormatting.supports_section_edit?
+
render :action => 'show'
end
@content.version = @page.content.version
@text = @content.text
- if params[:section].present?
+ if params[:section].present? && Redmine::WikiFormatting.supports_section_edit?
@section = params[:section].to_i
@text, @section_hash = Redmine::WikiFormatting.formatter.new(@text).get_section(@section)
render_404 if @text.blank?
@content.comments = params[:content][:comments]
@text = params[:content][:text]
- if params[:section].present?
+ if params[:section].present? && Redmine::WikiFormatting.supports_section_edit?
@section = params[:section].to_i
@section_hash = params[:section_hash]
@content.text = Redmine::WikiFormatting.formatter.new(@content.text).update_section(params[:section].to_i, @text, @section_hash)
text
end
+ # Returns true if the text formatter supports single section edit
+ def supports_section_edit?
+ (formatter.instance_methods & ['update_section', :update_section]).any?
+ end
+
# Returns a cache key for the given text +format+, +object+ and +attribute+ or nil if no caching should be done
def cache_key_for(format, object, attribute)
if object && attribute && !object.new_record? && object.respond_to?(:updated_on) && !format.blank?
assert_equal expected.gsub(%r{[\r\n\t]}, ''), Redmine::WikiFormatting::NullFormatter::Formatter.new(raw).to_html.gsub(%r{[\r\n\t]}, '')
end
+
+ def test_supports_section_edit
+ with_settings :text_formatting => 'textile' do
+ assert_equal true, Redmine::WikiFormatting.supports_section_edit?
+ end
+
+ with_settings :text_formatting => '' do
+ assert_equal false, Redmine::WikiFormatting.supports_section_edit?
+ end
+ end
end