diff --git a/app/controllers/users_controller.rb b/app/controllers/users_controller.rb
index fb35d8495..d1f98668c 100644
--- a/app/controllers/users_controller.rb
+++ b/app/controllers/users_controller.rb
@@ -532,9 +532,10 @@ class UsersController < ApplicationController
if @student_work.nil?
@student_work = StudentWork.new
end
+ @course = @homework.course
respond_to do |format|
format.js
- format.html {render :layout => 'new_base_user'}
+ format.html {render :layout => 'base_courses'}
end
else
render_403
diff --git a/app/controllers/words_controller.rb b/app/controllers/words_controller.rb
index 351be4e64..d1aa67483 100644
--- a/app/controllers/words_controller.rb
+++ b/app/controllers/words_controller.rb
@@ -74,9 +74,10 @@ class WordsController < ApplicationController
# render 'test/index'
# }
format.js {
+ #@reply_type = params[:reply_type]
@user_activity_id = params[:user_activity_id]
@activity = JournalsForMessage.find(parent_id)
- @is_activity = params[:is_activity]
+ @is_activity = params[:is_activity] if params[:is_activity]
}
end
@@ -98,6 +99,10 @@ class WordsController < ApplicationController
@user_activity_id = params[:user_activity_id] if params[:user_activity_id]
@is_activity = params[:is_activity].to_i if params[:is_activity]
@activity = @journal_destroyed.parent if @journal_destroyed.parent
+ unless @activity
+ redirect_to feedback_path(@user)
+ return
+ end
elsif @journal_destroyed.jour_type == 'HomeworkCommon'
@homework = HomeworkCommon.find @journal_destroyed.jour_id
if params[:user_activity_id]
diff --git a/app/helpers/issues_helper.rb b/app/helpers/issues_helper.rb
index 412c3f889..4ad3cb49d 100644
--- a/app/helpers/issues_helper.rb
+++ b/app/helpers/issues_helper.rb
@@ -1,463 +1,463 @@
-# encoding: utf-8
-#
-# Redmine - project management software
-# Copyright (C) 2006-2013 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.
-
-module IssuesHelper
- include ApplicationHelper
-
- def issue_list(issues, &block)
- ancestors = []
- issues.each do |issue|
- while (ancestors.any? && !issue.is_descendant_of?(ancestors.last))
- ancestors.pop
- end
- yield issue, ancestors.size
- ancestors << issue unless issue.leaf?
- end
- end
-
- # Renders a HTML/CSS tooltip
- #
- # To use, a trigger div is needed. This is a div with the class of "tooltip"
- # that contains this method wrapped in a span with the class of "tip"
- #
- #
\n"
- s.html_safe
- end
-
- def issues_destroy_confirmation_message(issues)
- issues = [issues] unless issues.is_a?(Array)
- message = l(:text_issues_destroy_confirmation)
- descendant_count = issues.inject(0) {|memo, i| memo += (i.right - i.left - 1)/2}
- if descendant_count > 0
- issues.each do |issue|
- next if issue.root?
- issues.each do |other_issue|
- descendant_count -= 1 if issue.is_descendant_of?(other_issue)
- end
- end
- if descendant_count > 0
- message << "\n" + l(:text_issues_destroy_descendants_confirmation, :count => descendant_count)
- end
- end
- message
- end
-
- def sidebar_queries
- unless @sidebar_queries
- @sidebar_queries = IssueQuery.visible.all(
- :order => "#{Query.table_name}.name ASC",
- # Project specific queries and global queries
- :conditions => (@project.nil? ? ["project_id IS NULL"] : ["project_id IS NULL OR project_id = ?", @project.id])
- )
- end
- @sidebar_queries
- end
-
- def query_links(title, queries)
- # links to #index on issues/show
- url_params = controller_name == 'issues' ? {:controller => 'issues', :action => 'index', :project_id => @project} : params
-
- content_tag('h3', h(title)) +
- queries.collect {|query|
- css = 'query'
- css << ' selected' if query == @query
- link_to(h(query.name), url_params.merge(:query_id => query), :class => css)
- }.join(' ').html_safe
- end
-
- def render_sidebar_queries
- out = ''.html_safe
- queries = sidebar_queries.select {|q| !q.is_public?}
- out << query_links(l(:label_my_queries), queries) if queries.any?
- queries = sidebar_queries.select {|q| q.is_public?}
- out << query_links(l(:label_query_plural), queries) if queries.any?
- out
- end
-
- # Returns the textual representation of a journal details
- # as an array of strings
- def details_to_strings(details, no_html=false, options={})
- options[:only_path] = (options[:only_path] == false ? false : true)
- options[:token] = options[:token] if options[:token]
- strings = []
- values_by_field = {}
- details.each do |detail|
-
- if detail.property == 'cf'
- field_id = detail.prop_key
- field = CustomField.find_by_id(field_id)
- if field && field.multiple?
- values_by_field[field_id] ||= {:added => [], :deleted => []}
- if detail.old_value
- values_by_field[field_id][:deleted] << detail.old_value
- end
- if detail.value
- values_by_field[field_id][:added] << detail.value
- end
- next
- end
- end
- strings << show_detail(detail, no_html, options)
-
- end
- values_by_field.each do |field_id, changes|
- detail = JournalDetail.new(:property => 'cf', :prop_key => field_id)
- if changes[:added].any?
- detail.value = changes[:added]
- strings << show_detail(detail, no_html, options)
- elsif changes[:deleted].any?
- detail.old_value = changes[:deleted]
- strings << show_detail(detail, no_html, options)
- end
- end
- strings
- end
-
- # Returns the textual representation of a single journal detail
- def show_detail(detail, no_html=false, options={})
- multiple = false
- case detail.property
- when 'attr'
- field = detail.prop_key.to_s.gsub(/\_id$/, "")
- label = l(("field_" + field).to_sym)
- case detail.prop_key
- when 'due_date', 'start_date'
- value = format_date(detail.value.to_date) if detail.value
- old_value = format_date(detail.old_value.to_date) if detail.old_value
-
- when 'project_id', 'status_id', 'tracker_id', 'assigned_to_id',
- 'priority_id', 'category_id', 'fixed_version_id'
- value = find_name_by_reflection(field, detail.value)
- old_value = find_name_by_reflection(field, detail.old_value)
-
- when 'estimated_hours'
- value = "%0.02f" % detail.value.to_f unless detail.value.blank?
- old_value = "%0.02f" % detail.old_value.to_f unless detail.old_value.blank?
-
- when 'parent_id'
- label = l(:field_parent_issue)
- value = "##{detail.value}" unless detail.value.blank?
- old_value = "##{detail.old_value}" unless detail.old_value.blank?
-
- when 'is_private'
- value = l(detail.value == "0" ? :general_text_No : :general_text_Yes) unless detail.value.blank?
- old_value = l(detail.old_value == "0" ? :general_text_No : :general_text_Yes) unless detail.old_value.blank?
- end
- when 'cf'
- custom_field = CustomField.find_by_id(detail.prop_key)
- if custom_field
- multiple = custom_field.multiple?
- label = custom_field.name
- value = format_value(detail.value, custom_field.field_format) if detail.value
- old_value = format_value(detail.old_value, custom_field.field_format) if detail.old_value
- end
- when 'attachment'
- label = l(:label_attachment)
- end
- call_hook(:helper_issues_show_detail_after_setting,
- {:detail => detail, :label => label, :value => value, :old_value => old_value })
-
- label ||= detail.prop_key
- value ||= detail.value
- old_value ||= detail.old_value
-
- unless no_html
- label = content_tag('strong', label)
- old_value = content_tag("i", h(old_value)) if detail.old_value
- old_value = content_tag("del", old_value) if detail.old_value and detail.value.blank?
- if detail.property == 'attachment' && !value.blank? && atta = Attachment.find_by_id(detail.prop_key)
- # Link to the attachment if it has not been removed
- if options[:token].nil?
- value = atta.filename
- else
- value = atta.filename
- end
- # 放大镜搜索功能
- # if options[:only_path] != false && atta.is_text?
- # value += link_to(
- # image_tag('magnifier.png'),
- # :controller => 'attachments', :action => 'show',
- # :id => atta, :filename => atta.filename
- # )
- # end
- else
- value = content_tag("i", h(value)) if value
- end
- end
- # 缺陷更新结果在消息中显示样式
- if no_html == "message"
- label = content_tag(:span, label, :class => "issue_update_message")
- old_value = content_tag("span", h(old_value)) if detail.old_value
- old_value = content_tag("del", old_value) if detail.old_value and detail.value.blank?
- if detail.property == 'attachment' && !value.blank? && atta = Attachment.find_by_id(detail.prop_key)
- # Link to the attachment if it has not been removed
- if options[:token].nil?
- value = atta.filename
- else
- value = atta.filename
- end
- else
- value = content_tag(:span, h(value), :class => "issue_update_message_value") if value
- end
- end
-
- if detail.property == 'attr' && detail.prop_key == 'description'
- s = l(:text_journal_changed_no_detail, :label => label)
- unless no_html
- diff_link = link_to l(:label_diff),
- {:controller => 'journals', :action => 'diff', :id => detail.journal_id,
- :detail_id => detail.id, :only_path => options[:only_path]},
- :title => l(:label_view_diff)
- s << " (#{ diff_link })"
- end
- s.html_safe
- elsif detail.value.present?
- case detail.property
- when 'attr', 'cf'
- if detail.old_value.present?
- l(:text_journal_changed, :label => label, :old => old_value, :new => value).html_safe
- elsif multiple
- l(:text_journal_added, :label => label, :value => value).html_safe
- else
- l(:text_journal_set_to, :label => label, :value => value).html_safe
- end
- when 'attachment'
- l(:text_journal_added, :label => label, :value => value).html_safe
- end
- else
- l(:text_journal_deleted, :label => label, :old => old_value).html_safe
- end
- end
-
- # Find the name of an associated record stored in the field attribute
- def find_name_by_reflection(field, id)
- unless id.present?
- return nil
- end
- association = Issue.reflect_on_association(field.to_sym)
- if association
- record = association.class_name.constantize.find_by_id(id)
- if record
- record.name.force_encoding('UTF-8') if record.name.respond_to?(:force_encoding)
- return record.name
- end
- end
- end
-
- # Renders issue children recursively
- def render_api_issue_children(issue, api)
- return if issue.leaf?
- api.array :children do
- issue.children.each do |child|
- api.issue(:id => child.id) do
- api.tracker(:id => child.tracker_id, :name => child.tracker.name) unless child.tracker.nil?
- api.subject child.subject
- render_api_issue_children(child, api)
- end
- end
- end
- end
-
- # this method is used to get all projects that tagged one tag
- # added by william
- def get_issues_by_tag(tag_name)
- Issue.tagged_with(tag_name).order('updated_on desc')
- end
-
-end
+# encoding: utf-8
+#
+# Redmine - project management software
+# Copyright (C) 2006-2013 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.
+
+module IssuesHelper
+ include ApplicationHelper
+
+ def issue_list(issues, &block)
+ ancestors = []
+ issues.each do |issue|
+ while (ancestors.any? && !issue.is_descendant_of?(ancestors.last))
+ ancestors.pop
+ end
+ yield issue, ancestors.size
+ ancestors << issue unless issue.leaf?
+ end
+ end
+
+ # Renders a HTML/CSS tooltip
+ #
+ # To use, a trigger div is needed. This is a div with the class of "tooltip"
+ # that contains this method wrapped in a span with the class of "tip"
+ #
+ #