comparison app/controllers/journals_controller.rb @ 909:cbb26bc654de redmine-1.3

Update to Redmine 1.3-stable branch (Redmine SVN rev 8964)
author Chris Cannam
date Fri, 24 Feb 2012 19:09:32 +0000
parents 0c939c159af4
children 433d4f72a19b
comparison
equal deleted inserted replaced
908:c6c2cbd0afee 909:cbb26bc654de
3 # 3 #
4 # This program is free software; you can redistribute it and/or 4 # This program is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU General Public License 5 # modify it under the terms of the GNU General Public License
6 # as published by the Free Software Foundation; either version 2 6 # as published by the Free Software Foundation; either version 2
7 # of the License, or (at your option) any later version. 7 # of the License, or (at your option) any later version.
8 # 8 #
9 # This program is distributed in the hope that it will be useful, 9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of 10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 # GNU General Public License for more details. 12 # GNU General Public License for more details.
13 # 13 #
14 # You should have received a copy of the GNU General Public License 14 # You should have received a copy of the GNU General Public License
15 # along with this program; if not, write to the Free Software 15 # along with this program; if not, write to the Free Software
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. 16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17 17
18 class JournalsController < ApplicationController 18 class JournalsController < ApplicationController
20 before_filter :find_issue, :only => [:new] 20 before_filter :find_issue, :only => [:new]
21 before_filter :find_optional_project, :only => [:index] 21 before_filter :find_optional_project, :only => [:index]
22 before_filter :authorize, :only => [:new, :edit, :diff] 22 before_filter :authorize, :only => [:new, :edit, :diff]
23 accept_rss_auth :index 23 accept_rss_auth :index
24 menu_item :issues 24 menu_item :issues
25 25
26 helper :issues 26 helper :issues
27 helper :custom_fields 27 helper :custom_fields
28 helper :queries 28 helper :queries
29 include QueriesHelper 29 include QueriesHelper
30 helper :sort 30 helper :sort
32 32
33 def index 33 def index
34 retrieve_query 34 retrieve_query
35 sort_init 'id', 'desc' 35 sort_init 'id', 'desc'
36 sort_update(@query.sortable_columns) 36 sort_update(@query.sortable_columns)
37 37
38 if @query.valid? 38 if @query.valid?
39 @journals = @query.journals(:order => "#{Journal.table_name}.created_on DESC", 39 @journals = @query.journals(:order => "#{Journal.table_name}.created_on DESC",
40 :limit => 25) 40 :limit => 25)
41 end 41 end
42 @title = (@project ? @project.name : Setting.app_title) + ": " + (@query.new_record? ? l(:label_changes_details) : @query.name) 42 @title = (@project ? @project.name : Setting.app_title) + ": " + (@query.new_record? ? l(:label_changes_details) : @query.name)
43 render :layout => false, :content_type => 'application/atom+xml' 43 render :layout => false, :content_type => 'application/atom+xml'
44 rescue ActiveRecord::RecordNotFound 44 rescue ActiveRecord::RecordNotFound
45 render_404 45 render_404
46 end 46 end
47 47
48 def diff 48 def diff
49 @issue = @journal.issue 49 @issue = @journal.issue
50 if params[:detail_id].present? 50 if params[:detail_id].present?
51 @detail = @journal.details.find_by_id(params[:detail_id]) 51 @detail = @journal.details.find_by_id(params[:detail_id])
52 else 52 else
53 @detail = @journal.details.detect {|d| d.prop_key == 'description'} 53 @detail = @journal.details.detect {|d| d.prop_key == 'description'}
54 end 54 end
55 (render_404; return false) unless @issue && @detail 55 (render_404; return false) unless @issue && @detail
56 @diff = Redmine::Helpers::Diff.new(@detail.value, @detail.old_value) 56 @diff = Redmine::Helpers::Diff.new(@detail.value, @detail.old_value)
57 end 57 end
58 58
59 def new 59 def new
60 journal = Journal.find(params[:journal_id]) if params[:journal_id] 60 journal = Journal.find(params[:journal_id]) if params[:journal_id]
61 if journal 61 if journal
62 user = journal.user 62 user = journal.user
63 text = journal.notes 63 text = journal.notes
67 end 67 end
68 # Replaces pre blocks with [...] 68 # Replaces pre blocks with [...]
69 text = text.to_s.strip.gsub(%r{<pre>((.|\s)*?)</pre>}m, '[...]') 69 text = text.to_s.strip.gsub(%r{<pre>((.|\s)*?)</pre>}m, '[...]')
70 content = "#{ll(Setting.default_language, :text_user_wrote, user)}\n> " 70 content = "#{ll(Setting.default_language, :text_user_wrote, user)}\n> "
71 content << text.gsub(/(\r?\n|\r\n?)/, "\n> ") + "\n\n" 71 content << text.gsub(/(\r?\n|\r\n?)/, "\n> ") + "\n\n"
72 72
73 render(:update) { |page| 73 render(:update) { |page|
74 page.<< "$('notes').value = \"#{escape_javascript content}\";" 74 page.<< "$('notes').value = \"#{escape_javascript content}\";"
75 page.show 'update' 75 page.show 'update'
76 page << "Form.Element.focus('notes');" 76 page << "Form.Element.focus('notes');"
77 page << "Element.scrollTo('update');" 77 page << "Element.scrollTo('update');"
78 page << "$('notes').scrollTop = $('notes').scrollHeight - $('notes').clientHeight;" 78 page << "$('notes').scrollTop = $('notes').scrollHeight - $('notes').clientHeight;"
79 } 79 }
80 end 80 end
81 81
82 def edit 82 def edit
83 (render_403; return false) unless @journal.editable_by?(User.current) 83 (render_403; return false) unless @journal.editable_by?(User.current)
84 if request.post? 84 if request.post?
85 @journal.update_attributes(:notes => params[:notes]) if params[:notes] 85 @journal.update_attributes(:notes => params[:notes]) if params[:notes]
86 @journal.destroy if @journal.details.empty? && @journal.notes.blank? 86 @journal.destroy if @journal.details.empty? && @journal.notes.blank?
91 end 91 end
92 else 92 else
93 respond_to do |format| 93 respond_to do |format|
94 format.html { 94 format.html {
95 # TODO: implement non-JS journal update 95 # TODO: implement non-JS journal update
96 render :nothing => true 96 render :nothing => true
97 } 97 }
98 format.js 98 format.js
99 end 99 end
100 end 100 end
101 end 101 end
102 102
103 private 103 private
104 104
105 def find_journal 105 def find_journal
106 @journal = Journal.find(params[:id]) 106 @journal = Journal.find(params[:id])
107 @project = @journal.journalized.project 107 @project = @journal.journalized.project
108 rescue ActiveRecord::RecordNotFound 108 rescue ActiveRecord::RecordNotFound
109 render_404 109 render_404