summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--app/helpers/wiki_helper.rb13
-rw-r--r--app/views/wiki/edit.html.erb7
-rw-r--r--test/unit/helpers/wiki_helper_test.rb45
3 files changed, 63 insertions, 2 deletions
diff --git a/app/helpers/wiki_helper.rb b/app/helpers/wiki_helper.rb
index 77ac01835..59448920b 100644
--- a/app/helpers/wiki_helper.rb
+++ b/app/helpers/wiki_helper.rb
@@ -51,4 +51,17 @@ module WikiHelper
link_to(h(parent.pretty_title), {:controller => 'wiki', :action => 'show', :id => parent.title, :project_id => parent.project, :version => nil})
})
end
+
+ # Returns the path for the Cancel link when editing a wiki page
+ def wiki_page_edit_cancel_path(page)
+ if page.new_record?
+ if parent = page.parent
+ project_wiki_page_path(parent.project, parent.title)
+ else
+ project_wiki_index_path(page.project)
+ end
+ else
+ project_wiki_page_path(page.project, page.title)
+ end
+ end
end
diff --git a/app/views/wiki/edit.html.erb b/app/views/wiki/edit.html.erb
index 566e96029..a1fc3d005 100644
--- a/app/views/wiki/edit.html.erb
+++ b/app/views/wiki/edit.html.erb
@@ -33,8 +33,11 @@
<p><label><%=l(:label_attachment_plural)%></label><%= render :partial => 'attachments/form' %></p>
</div>
-<p><%= submit_tag l(:button_save) %>
- <%= preview_link({:controller => 'wiki', :action => 'preview', :project_id => @project, :id => @page.title }, 'wiki_form') %></p>
+<p>
+ <%= submit_tag l(:button_save) %>
+ <%= preview_link({:controller => 'wiki', :action => 'preview', :project_id => @project, :id => @page.title }, 'wiki_form') %>
+ | <%= link_to l(:button_cancel), wiki_page_edit_cancel_path(@page) %>
+ </p>
<%= wikitoolbar_for 'content_text' %>
<% end %>
diff --git a/test/unit/helpers/wiki_helper_test.rb b/test/unit/helpers/wiki_helper_test.rb
new file mode 100644
index 000000000..7e3bc09d1
--- /dev/null
+++ b/test/unit/helpers/wiki_helper_test.rb
@@ -0,0 +1,45 @@
+# Redmine - project management software
+# Copyright (C) 2006-2015 Jean-Philippe Lang
+#
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License
+# as published by the Free Software Foundation; either version 2
+# of the License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+
+require File.expand_path('../../../test_helper', __FILE__)
+
+class WikiHelperTest < ActionView::TestCase
+ include WikiHelper
+ include Rails.application.routes.url_helpers
+
+ fixtures :projects, :users,
+ :roles, :member_roles, :members,
+ :enabled_modules, :wikis, :wiki_pages
+
+ def test_wiki_page_edit_cancel_path_for_new_page_without_parent_should_be_wiki_index
+ wiki = Wiki.find(1)
+ page = WikiPage.new(:wiki => wiki)
+ assert_equal '/projects/ecookbook/wiki/index', wiki_page_edit_cancel_path(page)
+ end
+
+ def test_wiki_page_edit_cancel_path_for_new_page_with_parent_should_be_parent
+ wiki = Wiki.find(1)
+ page = WikiPage.new(:wiki => wiki, :parent => wiki.find_page('Another_page'))
+ assert_equal '/projects/ecookbook/wiki/Another_page', wiki_page_edit_cancel_path(page)
+ end
+
+ def test_wiki_page_edit_cancel_path_for_existing_page_should_be_the_page
+ wiki = Wiki.find(1)
+ page = wiki.find_page('Child_1')
+ assert_equal '/projects/ecookbook/wiki/Child_1', wiki_page_edit_cancel_path(page)
+ end
+end