Conflicts:
	app/controllers/my_controller.rb
	app/views/contestnotifications/index.html.erb
	app/views/courses/_join_private_course.html.erb
	app/views/wiki/edit.html.erb
This commit is contained in:
alan 2014-10-23 11:41:15 +08:00
commit 6e77c5a0b8
11 changed files with 1243 additions and 420 deletions

View File

@ -1,3 +1,4 @@
<<<<<<< HEAD
# Redmine - project management software # Redmine - project management software
# Copyright (C) 2006-2013 Jean-Philippe Lang # Copyright (C) 2006-2013 Jean-Philippe Lang
# #
@ -280,3 +281,287 @@ class MyController < ApplicationController
render :nothing => true render :nothing => true
end end
end end
=======
# 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.
class MyController < ApplicationController
layout "users_base"
before_filter :require_login
helper :issues
helper :users
helper :custom_fields
BLOCKS = { 'issuesassignedtome' => :label_assigned_to_me_issues,
'issuesreportedbyme' => :label_reported_issues,
'issueswatched' => :label_watched_issues,
'news' => :label_news_latest,
'calendar' => :label_calendar,
'documents' => :label_document_plural,
'timelog' => :label_spent_time
}.merge(Redmine::Views::MyPage::Block.additional_blocks).freeze
DEFAULT_LAYOUT = { 'left' => ['issuesassignedtome'],
'right' => ['issuesreportedbyme']
}.freeze
def index
page
render :action => 'page'
end
# Show user's page
def page
@user = User.current
@Issues= Issue.visible.open.
where(:assigned_to_id => ([User.current.id] + User.current.group_ids))
@limit = 10
@feedback_count = @Issues.count
@feedback_pages = Paginator.new @feedback_count, @limit, params['page']
@offset ||= @feedback_pages.offset
@curse_attachments = @Issues[@offset, @limit]
@blocks = @user.pref[:my_page_layout] || DEFAULT_LAYOUT
end
def page2
@limit = 10
@user = User.current
@Issues= Issue.visible.open.
where(:assigned_to_id => ([User.current.id] + User.current.group_ids))
@feedback_count = @Issues.count
@feedback_pages = Paginator.new @feedback_count, @limit, params['page']
@offset ||= @feedback_pages.offset
@curse_attachments = @Issues[@offset, @limit]
@state = false
@blocks = @user.pref[:my_page_layout] || DEFAULT_LAYOUT
respond_to do |format|
format.js
end
end
# Edit user's account
def account
@user = User.current
lg=@user.login
@pref = @user.pref
diskfile = disk_filename('User', @user.id)
diskfile1 = diskfile + 'temp'
if request.post?
@user.safe_attributes = params[:user]
@user.pref.attributes = params[:pref]
@user.pref[:no_self_notified] = (params[:no_self_notified] == '1')
@user.login = params[:login]
unless @user.user_extensions.nil?
if @user.user_extensions.identity == 2
@user.firstname = params[:enterprise_name]
end
end
@se = @user.extensions
@se.school_id = params[:occupation] if params[:occupation]
@se.gender = params[:gender]
@se.location = params[:province] if params[:province]
@se.location_city = params[:city] if params[:city]
@se.identity = params[:identity].to_i if params[:identity]
@se.technical_title = params[:technical_title] if params[:technical_title]
@se.student_id = params[:no] if params[:no]
if @user.save && @se.save
# 头像保存
if File.exist?(diskfile1)
if File.exist?(diskfile)
File.delete(diskfile)
end
File.open(diskfile1, "rb") do |f|
buffer = f.read(10)
if buffer != "DELETE"
File.open(diskfile1, "rb") do |f1|
File.open(diskfile, "wb") do |f|
buffer = ""
while (buffer = f1.read(8192))
f.write(buffer)
end
end
end
# File.rename(diskfile + 'temp',diskfile);
end
end
end
# 确保文件被删除
if File.exist?(diskfile1)
File.delete(diskfile1)
end
@user.pref.save
@user.notified_project_ids = (@user.mail_notification == 'selected' ? params[:notified_project_ids] : [])
set_language_if_valid @user.language
flash[:notice] = l(:notice_account_updated)
redirect_to user_url(@user)
return
else
# 确保文件被删除
if File.exist?(diskfile1)
File.delete(diskfile1)
end
@user.login = lg
end
else
# 确保文件被删除
if File.exist?(diskfile1)
File.delete(diskfile1)
end
end
end
# Destroys user's account
def destroy
@user = User.current
unless @user.own_account_deletable?
redirect_to my_account_url
return
end
if request.post? && params[:confirm]
@user.destroy
if @user.destroyed?
logout_user
flash.now[:notice] = l(:notice_account_deleted)
end
redirect_to home_url
end
end
# Manage user's password
def password
@user = User.current
unless @user.change_password_allowed?
flash.now[:error] = l(:notice_can_t_change_password)
redirect_to my_account_url
return
end
if request.post?
if @user.check_password?(params[:password])
@user.password, @user.password_confirmation = params[:new_password], params[:new_password_confirmation]
if @user.save
flash.now[:notice] = l(:notice_account_password_updated)
redirect_to my_account_url
end
else
flash.now[:error] = l(:notice_account_wrong_password)
end
end
end
# Create a new feeds key
def reset_rss_key
if request.post?
if User.current.rss_token
User.current.rss_token.destroy
User.current.reload
end
User.current.rss_key
flash[:notice] = l(:notice_feeds_access_key_reseted)
end
redirect_to my_account_url
end
# Create a new API key
def reset_api_key
if request.post?
if User.current.api_token
User.current.api_token.destroy
User.current.reload
end
User.current.api_key
flash[:notice] = l(:notice_api_access_key_reseted)
end
redirect_to my_account_url
end
# User's page layout configuration
def page_layout
@user = User.current
@blocks = @user.pref[:my_page_layout] || DEFAULT_LAYOUT.dup
@block_options = []
BLOCKS.each do |k, v|
unless %w(top left right).detect {|f| (@blocks[f] ||= []).include?(k)}
@block_options << [l("my.blocks.#{v}", :default => [v, v.to_s.humanize]), k.dasherize]
end
end
end
# Add a block to user's page
# The block is added on top of the page
# params[:block] : id of the block to add
def add_block
block = params[:block].to_s.underscore
if block.present? && BLOCKS.key?(block)
@user = User.current
layout = @user.pref[:my_page_layout] || {}
# remove if already present in a group
%w(top left right).each {|f| (layout[f] ||= []).delete block }
# add it on top
layout['top'].unshift block
@user.pref[:my_page_layout] = layout
@user.pref.save
end
redirect_to my_page_layout_url
end
# Remove a block to user's page
# params[:block] : id of the block to remove
def remove_block
block = params[:block].to_s.underscore
@user = User.current
# remove block in all groups
layout = @user.pref[:my_page_layout] || {}
%w(top left right).each {|f| (layout[f] ||= []).delete block }
@user.pref[:my_page_layout] = layout
@user.pref.save
redirect_to my_page_layout_url
end
# Change blocks order on user's page
# params[:group] : group to order (top, left or right)
# params[:list-(top|left|right)] : array of block ids of the group
def order_blocks
group = params[:group]
@user = User.current
if group.is_a?(String)
group_items = (params["blocks"] || []).collect(&:underscore)
group_items.each {|s| s.sub!(/^block_/, '')}
if group_items and group_items.is_a? Array
layout = @user.pref[:my_page_layout] || {}
# remove group blocks if they are presents in other groups
%w(top left right).each {|f|
layout[f] = (layout[f] || []) - group_items
}
layout[group] = group_items
@user.pref[:my_page_layout] = layout
@user.pref.save
end
end
render :nothing => true
end
end
>>>>>>> d2f4b38eb6fd68a67940b8ffe735d8f7437acde1

View File

@ -1,26 +1,80 @@
<%= error_messages_for @contestnotifications %> <%= error_messages_for @contestnotifications %>
<script type="text/javascript">
function regexTitle()
{
var title = $.trim($("#contestnotification_title").val());
if(title.length ==0)
{
$("#title_span").text("<%= l(:label_no_contest_news_title) %>");
$("#title_span").css('color','#ff0000');
$("#title_span").focus();
return false;
}
else if(title.length <= 254)
{
$("#title_span").text("<%= l(:label_field_correct) %>");
$("#title_span").css('color','#008000');
return true;
}
else
{
$("#title_span").text("<%= l(:label_contest_news_title_condition) %>");
$("#title_span").css('color','#ff0000');
$("#title_span").focus();
return false;
}
}
//验证描述不能为空不能多余5000个字符
function regexDescription()
{
var description = $.trim($("#contestnotification_description").val());
if(description.length ==0)
{
$("#description_span").text("<%= l(:label_no_contest_news_description) %>");
$("#description_span").css('color','#ff0000');
$("#description_span").focus();
return false;
}
else if(description.length <= 5000)
{
$("#description_span").text("<%= l(:label_field_correct) %>");
$("#description_span").css('color','#008000');
return true;
}
else
{
$("#description_span").text("<%= l(:label_contest_news_condition) %>");
$("#description_span").css('color','#ff0000');
$("#description_span").focus();
return false;
}
}
</script>
<div class="add_frame_header" > <div class="add_frame_header" >
<%= l(:bale_news_notice) %> <%= l(:bale_news_notice) %>
</div> </div>
<div class="box tabular"> <div class="box tabular">
<p> <p>
<%= f.text_field :title, <%= f.text_field :title,
:required => true, :required => true,
:size => 60, :size => 60,
:maxlength => 60, :maxlength => 60,
:style => "width:488px;" :style => "width:488px;",
%> :onblur => "regexTitle();"
</p> %>
<p> </p>
<%= f.text_area :description, <span id="title_span" style="padding-left: 100px;"></span>
:required => true, <p>
:cols => 60, <%= f.text_area :description,
:rows => 11, :required => true,
:class => 'wiki-edit', :cols => 60,
:style => "width:490px;" :rows => 11,
%> :class => 'wiki-edit',
</p> :style => "width:490px;",
:onblur => "regexDescription();"
%>
</p>
<span id="description_span" style="padding-left: 100px;"></span>
</div> </div>
<%= wikitoolbar_for 'news_description' %> <%= wikitoolbar_for 'news_description' %>

View File

@ -1,3 +1,4 @@
<<<<<<< HEAD
<span style="font-size: 16px; border-bottom:1px solid #f0f0f0; margin-right: 15px;"> <span style="font-size: 16px; border-bottom:1px solid #f0f0f0; margin-right: 15px;">
<%= l(:label_notification) %> <%= l(:label_notification) %>
</span> </span>
@ -120,4 +121,137 @@
}); });
</script> </script>
=======
<script type="text/javascript">
function submitContestNews()
{
if(regexTitle() && regexDescription())
{
$("#contestnotifications-form").submit();
}
}
</script>
<span style="font-size: 16px; border-bottom:1px solid #f0f0f0; margin-right: 15px;">
<%= l(:label_notification) %>
</span>
<% if User.current.logged? && (User.current.admin? ||User.current == @contest.author) %>
<%= link_to(l(:bale_news_notice),
new_contest_contestnotification_path(@contest),
:class => 'icon icon-add',
:onclick => 'showAndScrollTo("add-contestnotifications", "contestnotifications_title"); return false;') %>
<% end %>
<% if @contest %>
<div id="add-contestnotifications" class="add_frame" style="display:none;">
<%= labelled_form_for @contestnotification, :url => contest_contestnotifications_path(@contest),
:html => {:id => 'contestnotifications-form', :multipart => true} do |f| %>
<%= render :partial => 'contestnotifications/form', :locals => {:f => f} %>
<input type="button" onclick="submitContestNews();" class="enterprise" value="<%= l(:button_create)%>"/>
|
<input type="button" onclick="$('#add-contestnotifications').hide(); return false;" class="enterprise" value="<%= l(:button_cancel)%>"/>
<% end if @contest %>
<div id="preview" class="wiki"></div>
</div>
<% end %>
<div>
<div style="margin-left: 20px;">
<span class="portrait">
<%= image_tag(url_to_avatar(@contest.author), :class => "avatar")%>
</span>
<span class="body">
<h3>
<%= link_to(@contest.author.lastname+@contest.author.firstname,
user_path(@contest.author))
%>
<%= @contest.name %></h3>
<p>
<strong>
<%= l(:label_bids_reward_method) %>
<span class="bonus">
<%= @contest.budget%>
</span>
</strong>
</p>
<div class="bid_description" style="width: 100%;word-break:break-all;word-wrap: break-word;">
<%= @contest.description %>
</div>
<span id="praise_tread" style="float: right">
<%= render :partial => "/praise_tread/praise_tread",
:locals => {:obj => @contest,
:show_flag => true,
:user_id =>User.current.id,
:horizontal => false}
%>
</span>
</span>
</div>
<div style="clear: both;"></div>
<br><br>
<% @contestnotificationss.each do |contestnotifications| %>
<table class="content-text-list">
<tr>
<td colspan="2" valign="top" width="50"><%= link_to image_tag(url_to_avatar(contestnotifications.author), :class => "avatar"), user_path(contestnotifications.author) %></td>
<td>
<table width="580px" border="0">
<tr>
<td colspan="2" valign="top">
<strong><%= link_to_user(contestnotifications.author) if contestnotifications.respond_to?(:author) %></strong><span style="margin-left: 4px;" class="font_lighter">
<%= l(:label_project_notice) %></span><span><%= link_to h(contestnotifications.title), contest_contestnotification_path(@contest, contestnotifications) %></span>
<span style="float: right">
<%= link_to l(:button_edit), edit_contest_contestnotification_path(@contest, contestnotifications) if (User.current.admin? && User.current.logged? )||(User.current == @contest.author && User.current.logged?) %>
<%= delete_link contest_contestnotification_path(@contest, contestnotifications) if (User.current.admin? && User.current.logged? )||(User.current == @contest.author && User.current.logged?) %>
</span>
</td>
</tr>
<tr>
<td colspan="2" width="580px">
<span class="font_description"><%= textilizable(contestnotifications, :description) %></span></td>
</tr>
<tr>
<td align="left"><span class="font_lighter"> <%= l :label_update_time %>
&nbsp;<%= format_time(contestnotifications.created_at) %></span></td>
<td width="350" align="right" class="a"><%= link_to l(:label_check_comment), contest_contestnotification_path(@contest, contestnotifications) %><%#= "(#{l(:label_x_comments, :count => contestnotifications.notificationcomments_count)})" if contestnotifications.notificationcomments_count >= 0 %></td>
</tr>
</table>
</td>
</tr>
</table>
<% end %>
</div>
<!--end-->
<div style="padding-right: 10px">
<div class="pagination">
<ul>
<%= pagination_links_full @contestnotifications_pages %>
</ul>
</div>
<% content_for :header_tags do %>
<%= auto_discovery_link_tag(:atom, params.merge({:format => 'atom', :page => nil, :key => User.current.rss_key})) %>
<%= stylesheet_link_tag 'scm' %>
<% end %>
<% html_title(l(:label_contest_notification)) -%>
</div>
<script type='text/javascript'>
$(document).ready(function ($) {
$('.content-text-list').each(function () {
$(this).find('.delete_icon').hide();
$(this).mouseenter(function (event) {
$(this).find('.delete_icon').show();
});
$(this).mouseleave(function (event) {
$(this).find('.delete_icon').hide();
});
});
});
</script>
>>>>>>> d2f4b38eb6fd68a67940b8ffe735d8f7437acde1
<!--end--> <!--end-->

View File

@ -1,11 +1,17 @@
<script type="text/javascript">
function submitContestNews()
{
if(regexTitle() && regexDescription())
{
$("#contestnotifications-form").submit();
}
}
</script>
<%= labelled_form_for @contestnotification, <%= labelled_form_for @contestnotification,
:url => contest_contestnotifications_path(@contest), :url => contest_contestnotifications_path(@contest),
:html => { :id => 'contestnotifications-form', :multipart => true } do |f| %> :html => { :id => 'contestnotifications-form', :multipart => true } do |f| %>
<%= render :partial => 'contestnotifications/form', :locals => { :f => f } %> <%= render :partial => 'contestnotifications/form', :locals => { :f => f } %>
<%= submit_tag l(:button_create), :class => "whiteButton m3p10 h30" %> <input type="button" onclick="submitContestNews();" class="enterprise" value="<%= l(:button_create)%>"/>
<%= submit_tag l(:button_cancel), :class => "whiteButton m3p10 h30",:onclick => "cancel();" %> <%= link_to l(:button_cancel), contest_contestnotifications_path(@contest.id) %>
<% end %> <% end %>
<div id="preview" class="wiki"></div> <div id="preview" class="wiki"></div>

View File

@ -1,3 +1,4 @@
<<<<<<< HEAD
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"> <html xmlns="http://www.w3.org/1999/xhtml">
<head> <head>
@ -73,3 +74,80 @@
</body> </body>
</html> </html>
=======
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>快速进入课程通道</title>
<style>
body{ font-size:12px; font-family:"微软雅黑","宋体"; line-height:1.9; background:#fff; font-style:normal;}
div,html,img,ul,li,p,body,h1,h2,h3,h4,p,a,table,tr,td,fieldset,input,span{ margin:0; padding:0;}
div,img,tr,td{ border:0;}
table,tr,td{border:0; cellspacing:0; cellpadding:0;}
ul,li{ list-style-type:none}
.cl{ clear:both; overflow:hidden; }
a{ text-decoration:none; }
a:hover{ }
#popbox{width:488px;height:308px;}
.alert .C{width:476px;height:296px;position:absolute;left:5px;top:5px; }
.C_top{ margin-top:20px; width:368px; height:100px; background:#e9e9e9; padding:0px 60px; }
.C_top h2{ color:#1c1d1d; font-size:24px; font-style:normal; font-weight:normal;}
.C_top p{ color:#a9aaaa; line-height:22px;}
.C_form{ margin:20px 0 0 60px;}
.C_form ul li{ font-size:14px; color:#3f3a39; line-height:30px; }
.C_form ul li input{ margin-left:30px; border:0px; border:1px solid #e1e1e1; color:#898989; padding-left:5px; -moz-border-radius:5px; -webkit-border-radius:5px; border-radius:5px; }
.C_form ul li.mB5{ color:#898989; font-size:12px; padding-left:90px;}
.width190{ width:190px; height:26px; border-color:#e1e1e1;}
.C_form a{ font-size:12px; color:#15bccf; float:left; display:block; height:40px; width:200px; margin-top:25px;}
.C_form a:hover{ text-decoration:underline;}
.C_form a.btn{ display:block; width:100px; height:36px; padding-top:4px; text-align: center; background:#15bccf; color:#fff; font-size:14px; margin:20px 20px 0 95px;}
.C_form a.btn:hover{ background:#ff821d;}
</style>
<script type="text/javascript">
function submit_form(obj)
{
hideModal(obj);
$("#new-watcher-form").submit();
}
</script>
</head>
<body>
<div id="popbox">
<div class="C" >
<div class="C_top">
<h2>快速进入课程通道</h2>
<p>只要持有课程ID和密码就可快速加入所在课程。课程页面搜索不到的私有课程只能从此通道进入哦</p>
</div>
<div class="C_form">
<%= form_tag({:controller => 'courses',
:action => 'join'},
:remote => true,
:method => :post,
:id => 'new-watcher-form') do %>
<ul>
<li>
<span class="tips">课&nbsp;程&nbsp;ID</span>
<input class=" width190" name="object_id" id="object_id" type="text" value="" >
</li>
<li class="mB5">课程ID是所在课程网址中显示的序号</li>
<li>
<span class="tips">密&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;码:</span>
<input class=" width190" type="password" name="course_password" id="course_password" value="" >
</li>
<li>
<a href="#" class="btn" onclick="submit_form(this);"><%= l(:label_new_join) %></a>
<a href="#" onclick="hideModal(this);"><%= l(:button_cancel)%></a>
</li>
</ul>
<% end%>
</div>
</div><!---- C end---->
</div>
</body>
</html>
>>>>>>> d2f4b38eb6fd68a67940b8ffe735d8f7437acde1

View File

@ -281,7 +281,7 @@
<%= yield %> <%= yield %>
<%= call_hook :view_layouts_base_content %> <%= call_hook :view_layouts_base_content %>
<div style="clear:both;"></div> <div style="clear:both;"></div>
<%= render_flash_messages %> <%#= render_flash_messages %>
</div> </div>

View File

@ -1,35 +1,65 @@
<% if @project.shared_versions.any? %> <% if @project.shared_versions.any? %>
<table class="list versions"> <table class="list versions" style="table-layout: fixed;">
<thead><tr> <thead>
<th><%= l(:label_version) %></th> <tr>
<th><%= l(:field_effective_date) %></th> <th>
<th><%= l(:field_description) %></th> <%= l(:label_version) %>
<th><%= l(:field_status) %></th> </th>
<th><%= l(:field_sharing) %></th> <th>
<th><%= l(:label_wiki_page) %></th> <%= l(:field_effective_date) %>
</th>
<th>
<%= l(:field_description) %>
</th>
<th>
<%= l(:field_status) %>
</th>
<th>
<%= l(:field_sharing) %>
</th>
<th>
<%= l(:label_wiki_page) %>
</th>
<th style="width:15%"></th> <th style="width:15%"></th>
</tr></thead> </tr></thead>
<tbody> <tbody>
<% for version in @project.shared_versions.sort %> <% for version in @project.shared_versions.sort %>
<tr class="version <%= cycle 'odd', 'even' %> <%=h version.status %> <%= 'shared' if version.project != @project %>"> <tr class="version <%= cycle 'odd', 'even' %> <%=h version.status %> <%= 'shared' if version.project != @project %>">
<td class="name"><%= link_to_version version %></td> <td class="name">
<td class="date"><%= format_date(version.effective_date) %></td> <%= link_to_version version %>
<td class="description"><%=h version.description %></td> </td>
<td class="status"><%= l("version_status_#{version.status}") %></td> <td class="date">
<td class="sharing"><%=h format_version_sharing(version.sharing) %></td> <%= format_date(version.effective_date) %>
<td><%= link_to_if_authorized(h(version.wiki_page_title), {:controller => 'wiki', :action => 'show', :project_id => version.project, :id => Wiki.titleize(version.wiki_page_title)}) || h(version.wiki_page_title) unless version.wiki_page_title.blank? || version.project.wiki.nil? %></td> </td>
<td class="buttons"> <td class="description">
<% if version.project == @project && User.current.allowed_to?(:manage_versions, @project) %> <%=h version.description %>
<%= link_to l(:button_edit), edit_version_path(version), :class => 'icon icon-edit' %> </td>
<%= delete_link version_path(version) %> <td class="status">
<% end %> <%= l("version_status_#{version.status}") %>
</td> </td>
</tr> <td class="sharing">
<% end; reset_cycle %> <%=h format_version_sharing(version.sharing) %>
</tbody> </td>
<td style="overflow: hidden;text-overflow: ellipsis;white-space: nowrap;" title="<%= h(version.wiki_page_title)%>">
<%= link_to_if_authorized(h(version.wiki_page_title), {:controller => 'wiki',
:action => 'show',
:project_id => version.project,
:id => Wiki.titleize(version.wiki_page_title)}) || h(version.wiki_page_title) unless version.wiki_page_title.blank? || version.project.wiki.nil? %>
</td>
<td class="buttons">
<% if version.project == @project && User.current.allowed_to?(:manage_versions, @project) %>
<%= link_to l(:button_edit), edit_version_path(version), :class => 'icon icon-edit' %>
<%= delete_link version_path(version) %>
<% end %>
</td>
</tr>
<% end; reset_cycle %>
</tbody>
</table> </table>
<% else %> <% else %>
<p class="nodata"><%= l(:label_no_data) %></p> <p class="nodata">
<%= l(:label_no_data) %>
</p>
<% end %> <% end %>
<div class="contextual"> <div class="contextual">

View File

@ -48,353 +48,485 @@
<% if e.act_type == 'JournalsForMessage' || e.act_type == 'Bid' || e.act_type == 'Journal'|| e.act_type == 'Changeset' || e.act_type == 'Message' || e.act_type == 'Principal' || e.act_type == 'News' || e.act_type == 'Issue' || e.act_type == 'Contest'%> <% if e.act_type == 'JournalsForMessage' || e.act_type == 'Bid' || e.act_type == 'Journal'|| e.act_type == 'Changeset' || e.act_type == 'Message' || e.act_type == 'Principal' || e.act_type == 'News' || e.act_type == 'Issue' || e.act_type == 'Contest'%>
<table width="660" border="0" align="left" style="border-bottom: 1px dashed rgb(204, 204, 204); margin-bottom: 10px;font-size:14px;"> <table width="660" border="0" align="left" style="border-bottom: 1px dashed rgb(204, 204, 204); margin-bottom: 10px;font-size:14px;">
<tr> <tr>
<td colspan="2" valign="top" width="50"><%= image_tag(url_to_avatar(e.user), :class => "avatar") %></td> <td colspan="2" valign="top" width="50">
<%= image_tag(url_to_avatar(e.user), :class => "avatar") %>
</td>
<td> <td>
<table width="580" border="0" class="info-break"> <table width="580" border="0" class="info-break">
<% case e.act_type %> <% case e.act_type %>
<% when 'JournalsForMessage' %> <% when 'JournalsForMessage' %>
<tr> <tr>
<td colspan="2" valign="top">
<% if User.current.login == e.user.try(:login) %>
<strong>
<%= link_to("#{l(:label_i)}", user_path(e.user_id)) %>
</strong>
&nbsp;
<% else %>
<strong><%= link_to("#{e.user.name}", user_path(e.user_id)) %></strong>
<% end %>
<span class="font_lighter">
<%= l(:label_have_feedback) %>
<%= link_to("#{e.act.user.name}", user_path(e.act.user.id)) %><%= l(:label_of_feedback) + l(:label_layouts_feedback) %>
</span>
</td>
</tr>
<tr>
<td colspan="2" width="580">
<p class="font_description"> <%= textAreailizable act.notes %> </p>
<div style="display: inline-block; float: right; margin-top: 0px">
<span>
<%= link_to(l(:label_goto), user_newfeedback_user_path(e.user_id)) %>
</span>
</div>
</td>
</tr>
<tr>
<td>
<div style="display: inline-block; float: left; margin-top: 0px" width="200" align="right" class="a">
<span class="font_lighter"> <%= (l(:label_update_time).to_s << ':' << format_time(e.act.created_on)).to_s %></span>
</div>
<div style="display: inline-block; float: right; margin-top: 0px"></div>
</td>
</tr>
<% when 'Bid' %>
<tr>
<% if act.reward_type == 3 && @show_course == 1%>
<% if e.user == User.current %>
<td colspan="2" valign="top"> <td colspan="2" valign="top">
<strong> <% if User.current.login == e.user.try(:login) %>
<%= link_to("#{l(:label_i)}", user_path(e.user_id)) %> <strong>
</strong> <%= link_to("#{l(:label_i)}", user_path(e.user_id)) %>
</strong>
&nbsp;
<% else %>
<strong>
<%= link_to("#{e.user.name}", user_path(e.user_id)) %>
</strong>
<% end %>
<span class="font_lighter"> <span class="font_lighter">
<%= l(:label_i_new_activity) %> <%= l(:label_have_feedback) %>
<%= link_to("#{e.act.user.name}", user_path(e.act.user.id)) %>
<%= l(:label_of_feedback) + l(:label_layouts_feedback) %>
</span> </span>
<%= link_to format_activity_title("#{l(:label_active_homework)}##{act.id}:#{act.name}"), respond_path(e.act_id) %>
</td> </td>
<% else %> </tr>
<td colspan="2" valign="top"> <tr>
<strong> <td colspan="2" width="580">
<%= link_to(h(e.user), user_path(e.user_id)) %> <p class="font_description">
</strong>&nbsp; <%= textAreailizable act.notes %>
<span class="font_lighter"> </p>
<%= l(:label_new_activity) %> <div style="display: inline-block; float: right; margin-top: 0px">
</span>&nbsp; <span>
<%= link_to format_activity_title("#{l(:label_active_homework)}##{act.id}:#{act.name}"), respond_path(e.act_id) %> <%= link_to(l(:label_goto), user_newfeedback_user_path(e.user_id)) %>
</span>
</div>
</td> </td>
<% end %> </tr>
<% else %> <tr>
<% if e.user == User.current %> <td>
<td colspan="2" valign="top"> <div style="display: inline-block; float: left; margin-top: 0px" width="200" align="right" class="a">
<strong> <%= link_to("#{l(:label_i)}", user_path(e.user_id)) %></strong> <span class="font_lighter">
<span class="font_lighter"><%= l(:label_i_new_activity) %></span> <%= (l(:label_update_time).to_s << ':' << format_time(e.act.created_on)).to_s %>
<%= link_to format_activity_title("#{l(:label_active_call)}##{act.id}:#{act.name}"), respond_path(e.act_id) %> </span>
</div>
<div style="display: inline-block; float: right; margin-top: 0px"></div>
</td> </td>
<% else %> </tr>
<td colspan="2" valign="top"> <% when 'Bid' %>
<strong><%= link_to(h(e.user), user_path(e.user_id)) %></strong>&nbsp; <tr>
<span class="font_lighter"><%= l(:label_new_activity) %></span>&nbsp; <% if act.reward_type == 3 && @show_course == 1%>
<%= link_to format_activity_title("#{l(:label_active_call)}##{act.id}:#{act.name}"), respond_path(e.act_id) %> <% if e.user == User.current %>
<td colspan="2" valign="top">
<strong>
<%= link_to("#{l(:label_i)}", user_path(e.user_id)) %>
</strong>
<span class="font_lighter">
<%= l(:label_i_new_activity) %>
</span>
<%= link_to format_activity_title("#{l(:label_active_homework)}##{act.id}:#{act.name}"), respond_path(e.act_id) %>
</td>
<% else %>
<td colspan="2" valign="top">
<strong>
<%= link_to(h(e.user), user_path(e.user_id)) %>
</strong>&nbsp;
<span class="font_lighter">
<%= l(:label_new_activity) %>
</span>&nbsp;
<%= link_to format_activity_title("#{l(:label_active_homework)}##{act.id}:#{act.name}"), respond_path(e.act_id) %>
</td>
<% end %>
<% else %>
<% if e.user == User.current %>
<td colspan="2" valign="top">
<strong>
<%= link_to("#{l(:label_i)}", user_path(e.user_id)) %>
</strong>
<span class="font_lighter">
<%= l(:label_i_new_activity) %>
</span>
<%= link_to format_activity_title("#{l(:label_active_call)}##{act.id}:#{act.name}"), respond_path(e.act_id) %>
</td>
<% else %>
<td colspan="2" valign="top">
<strong>
<%= link_to(h(e.user), user_path(e.user_id)) %>
</strong>&nbsp;
<span class="font_lighter">
<%= l(:label_new_activity) %>
</span>&nbsp;
<%= link_to format_activity_title("#{l(:label_active_call)}##{act.id}:#{act.name}"), respond_path(e.act_id) %>
</td>
<% end %>
<% end %>
</tr>
<tr>
<td colspan="2" width="580">
<p class="font_description">
<%=textAreailizable act, :description %>
</p></td>
</tr>
<tr>
<td>
<div style="display: inline-block; float: left; margin-top: 0px" width="200" align="right" class="a">
<span class="font_lighter">
<%= (l(:label_update_time).to_s << ':' << format_time(e.act.created_on)).to_s %>
</span>
</div>
<div style="display: inline-block; float: right; margin-top: 0px">
<span>
<%= link_to l(:label_find_all_comments), respond_path(e.act_id) %>
</span>
<a class="font_lighter">
<%= l(:label_comments_count, :count => e.act.commit) %>
</a>
</div>
</td> </td>
<% end %> </tr>
<% end %> <% when 'Journal' %>
</tr> <tr>
<tr> <% if e.user == User.current %>
<td colspan="2" width="580"> <td colspan="2" valign="top">
<p class="font_description"> <%=textAreailizable act, :description %> </p></td> <strong>
</tr> <%= link_to("#{l(:label_i)}", user_path(e.user_id)) %>
<tr> </strong>
<td> &nbsp;
<div style="display: inline-block; float: left; margin-top: 0px" width="200" align="right" class="a"> <span class="font_lighter">
<span class="font_lighter"> <%= (l(:label_update_time).to_s << ':' << format_time(e.act.created_on)).to_s %></span> <%= l(:label_i_new_activity) %>
</div> </span>
<div style="display: inline-block; float: right; margin-top: 0px"> &nbsp;
<span><%= link_to l(:label_find_all_comments), respond_path(e.act_id) %></span> <%= link_to(l(:label_activity_project)+act.issue.project.name, project_path(act.issue.project.id)) %>
<a class="font_lighter"><%= l(:label_comments_count, :count => e.act.commit) %></a> <%= link_to format_activity_title("#{act.issue.tracker} ##{act.issue.id}: #{act.issue.subject}"),
</div> {:controller => 'issues', :action => 'show', :id => act.issue.id, :anchor => "change-#{act.id}"} %>
</td> </td>
</tr> <% else %>
<% when 'Journal' %> <td colspan="2" valign="top">
<tr> <strong>
<% if e.user == User.current %> <%= link_to(h(e.user), user_path(e.user_id)) %>
<td colspan="2" valign="top"> </strong>
<strong><%= link_to("#{l(:label_i)}", user_path(e.user_id)) %></strong>&nbsp; &nbsp;
<span class="font_lighter"><%= l(:label_i_new_activity) %></span>&nbsp; <span class="font_lighter">
<%= link_to(l(:label_activity_project)+act.issue.project.name, project_path(act.issue.project.id)) %> <%= l(:label_new_activity) %>
<%= link_to format_activity_title("#{act.issue.tracker} ##{act.issue.id}: #{act.issue.subject}"), </span>
{:controller => 'issues', :action => 'show', :id => act.issue.id, :anchor => "change-#{act.id}"} %> &nbsp;
</td> <%= link_to(l(:label_activity_project)+act.issue.project.name, project_path(act.issue.project.id)) %>
<% else %> <%= link_to format_activity_title("#{act.issue.tracker} ##{act.issue.id}: #{act.issue.subject}"),
<td colspan="2" valign="top"> {:controller => 'issues', :action => 'show', :id => act.issue.id, :anchor => "change-#{act.id}"} %>
<strong><%= link_to(h(e.user), user_path(e.user_id)) %></strong>&nbsp; </td>
<span class="font_lighter"><%= l(:label_new_activity) %></span>&nbsp; <% end %>
<%= link_to(l(:label_activity_project)+act.issue.project.name, project_path(act.issue.project.identifier)) %> </tr>
<%= link_to format_activity_title("#{act.issue.tracker} ##{act.issue.id}: #{act.issue.subject}"), <tr>
{:controller => 'issues', :action => 'show', :id => act.issue.id, :anchor => "change-#{act.id}"} %> <% if act.notes.nil? %>
</td> <% desStr = '' %>
<% end %> <% else %>
</tr> <% desStr= textAreailizable(act, :notes) %>
<tr> <% end %>
<% if act.notes.nil? %> <td colspan="2" width="580">
<% desStr = '' %> <p class="font_description">
<% else %> <%= desStr %>
<% desStr= textAreailizable(act, :notes) %> </p>
<% end %> </td>
<td colspan="2" width="580"><p class="font_description"> <%= desStr %> </p> </tr>
</td> <tr>
</tr> <td>
<tr> <div style="display: inline-block; float: left; margin-top: 0px" width="200" align="right" class="a">
<td> <span class="font_lighter">
<div style="display: inline-block; float: left; margin-top: 0px" width="200" align="right" class="a"> <%= (l(:label_update_time).to_s << ':' << format_time(e.act.created_on)).to_s %>
<span class="font_lighter"> <%= (l(:label_update_time).to_s << ':' << format_time(e.act.created_on)).to_s %></span> </span>
</div> </div>
<div style="display: inline-block; float: right; margin-top: 0px"></div> <div style="display: inline-block; float: right; margin-top: 0px"></div>
</td> </td>
</tr> </tr>
<% when 'Changeset' %> <% when 'Changeset' %>
<tr> <tr>
<% if e.user == User.current %> <% if e.user == User.current %>
<td colspan="2" valign="top"> <td colspan="2" valign="top">
<strong><%= link_to("#{l(:label_i)}", user_path(e.user_id)) %></strong>&nbsp; <strong>
<span class="font_lighter"><%= l(:label_i_new_activity) %></span>&nbsp; <%= link_to("#{l(:label_i)}", user_path(e.user_id)) %>
<%= link_to format_activity_title(act.title), </strong>
{:controller => 'repositories', &nbsp;
:action => 'revision', <span class="font_lighter">
:id => act.repository.project, <%= l(:label_i_new_activity) %>
:repository_id => act.repository.identifier_param, </span>
:rev => act.identifier} %> &nbsp;
</td> <%= link_to format_activity_title(act.title),
<% else %> {:controller => 'repositories',
<td colspan="2" valign="top"> :action => 'revision',
<strong><%= link_to(h(e.user), user_path(e.user_id)) %></strong>&nbsp; :id => act.repository.project,
<span class="font_lighter"><%= l(:label_new_activity) %></span>&nbsp; :repository_id => act.repository.identifier_param,
<%= link_to format_activity_title(act.title), :rev => act.identifier} %>
{:controller => 'repositories', </td>
:action => 'revision', <% else %>
:id => act.repository.project, <td colspan="2" valign="top">
:repository_id => act.repository.identifier_param, <strong>
:rev => act.identifier} %> <%= link_to(h(e.user), user_path(e.user_id)) %>
</td> </strong>
<% end %> &nbsp;
</tr> <span class="font_lighter">
<tr> <%= l(:label_new_activity) %>
<td colspan="2" width="580"> </span>
<p class="font_description"> <%= textAreailizable act,:long_comments %> </p></td> &nbsp;
</tr> <%= link_to format_activity_title(act.title),
<tr> {:controller => 'repositories',
<td> :action => 'revision',
<div style="display: inline-block; float: left; margin-top: 0px" width="200" align="right" class="a"> :id => act.repository.project,
<span class="font_lighter"> <%= format_time(e.act.committed_on) %></span> :repository_id => act.repository.identifier_param,
</div> :rev => act.identifier} %>
<div style="display: inline-block; float: right; margin-top: 0px"> </td>
<span><%= link_to l(:label_find_all_comments), <% end %>
{:controller => 'repositories', </tr>
:action => 'revision', <tr>
:id => act.repository.project, <td colspan="2" width="580">
:repository_id => act.repository.identifier_param, <p class="font_description">
:rev => act.identifier} %> <%= textAreailizable act,:long_comments %>
</span> </p>
<a class="font_lighter"><%= l(:label_comments_count, :count => e.act.count) %></a> </td>
</div> </tr>
</td> <tr>
</tr> <td>
<% when 'Message' %> <div style="display: inline-block; float: left; margin-top: 0px" width="200" align="right" class="a">
<tr> <span class="font_lighter">
<% if e.user == User.current %> <%= format_time(e.act.committed_on) %>
<td colspan="2" valign="top"> </span>
<strong><%= link_to("#{l(:label_i)}", user_path(e.user_id)) %></strong>&nbsp; </div>
<span class="font_lighter"><%= l(:label_i_new_activity) %></span>&nbsp; <div style="display: inline-block; float: right; margin-top: 0px">
<%= link_to format_activity_title("#{act.board.name}: #{act.subject}"), <span><%= link_to l(:label_find_all_comments),
{:controller => 'messages', {:controller => 'repositories',
:action => 'show', :action => 'revision',
:board_id => act.board_id}.merge(act.parent_id.nil? ? {:id => act.id} : {:id => act.parent_id, :r => act.id, :anchor => "message-#{act.id}"}) %> :id => act.repository.project,
</td> :repository_id => act.repository.identifier_param,
<% else %> :rev => act.identifier} %>
<td colspan="2" valign="top"> </span>
<strong><%= link_to(h(e.user), user_path(e.user_id)) %></strong>&nbsp; <a class="font_lighter">
<span class="font_lighter"><%= l(:label_new_activity) %></span>&nbsp; <%= l(:label_comments_count, :count => e.act.count) %>
<%= link_to format_activity_title("#{act.board.name}: #{act.subject}"), </a>
{:controller => 'messages', </div>
:action => 'show', </td>
:board_id => act.board_id}.merge(act.parent_id.nil? ? {:id => act.id} : {:id => act.parent_id, :r => act.id, :anchor => "message-#{act.id}"}) %> </tr>
</td> <% when 'Message' %>
<% end %> <tr>
</tr> <% if e.user == User.current %>
<tr> <td colspan="2" valign="top">
<td colspan="2" width="580"> <strong>
<p class="font_description"> <%= textAreailizable(act,:content) %> </p> <%= link_to("#{l(:label_i)}", user_path(e.user_id)) %>
</td> </strong>
</tr> &nbsp;
<tr> <span class="font_lighter">
<td> <%= l(:label_i_new_activity) %>
<div style="display: inline-block; float: left; margin-top: 0px" width="200" align="right" class="a"> </span>
<span class="font_lighter"> <%= (l(:label_update_time).to_s << ':' << format_time(e.act.created_on)).to_s %></span> &nbsp;
</div> <%= link_to format_activity_title("#{act.board.name}: #{act.subject}"),
<div style="display: inline-block; float: right; margin-top: 0px"></div> {:controller => 'messages',
</td> :action => 'show',
</tr> :board_id => act.board_id}.merge(act.parent_id.nil? ? {:id => act.id} : {:id => act.parent_id, :r => act.id, :anchor => "message-#{act.id}"}) %>
<% when 'Principal' %> </td>
<tr> <% else %>
<% if e.user == User.current %> <td colspan="2" valign="top">
<td colspan="2" valign="top"> <strong>
<strong><%= link_to("#{l(:label_i)}", user_path(e.user_id)) %></strong>&nbsp; <%= link_to(h(e.user), user_path(e.user_id)) %>
<span class="font_lighter"><%= l(:label_new_user) %></span> </strong>
</td> &nbsp;
<% else %> <span class="font_lighter">
<td colspan="2" valign="top"> <%= l(:label_new_activity) %>
<strong><%= link_to(h(e.user), user_path(e.user_id)) %></strong>&nbsp; </span>
<span class="font_lighter"><%= l(:label_new_user) %></span> &nbsp;
</td> <%= link_to format_activity_title("#{act.board.name}: #{act.subject}"),
<% end %> {:controller => 'messages',
</tr> :action => 'show',
<tr> :board_id => act.board_id}.merge(act.parent_id.nil? ? {:id => act.id} : {:id => act.parent_id, :r => act.id, :anchor => "message-#{act.id}"}) %>
<td colspan="2" width="580"><p class="font_description"></p></td> </td>
</tr> <% end %>
<tr> </tr>
<td> <tr>
<div style="display: inline-block; float: left; margin-top: 0px" width="200" align="right" class="a"> <td colspan="2" width="580">
<span class="font_lighter"> <%= (l(:label_update_time).to_s << ':' << format_time(e.act.created_on)).to_s %></span> <p class="font_description">
</div> <%= textAreailizable(act,:content) %>
<div style="display: inline-block; float: right; margin-top: 0px"></div> </p>
</td> </td>
</tr> </tr>
<% when 'News' %> <tr>
<tr> <td>
<% if e.user == User.current %> <div style="display: inline-block; float: left; margin-top: 0px" width="200" align="right" class="a">
<td colspan="2" valign="top"> <span class="font_lighter">
<strong><%= link_to("#{l(:label_i)}", user_path(e.user_id)) %></strong>&nbsp; <%= (l(:label_update_time).to_s << ':' << format_time(e.act.created_on)).to_s %>
<span class="font_lighter"><%= l(:label_i_new_activity) %></span>&nbsp; </span>
<%= link_to format_activity_title("#{l(:label_news)}: #{act.title}"), {:controller => 'news', :action => 'show', :id => act.id} %> </div>
</td> <div style="display: inline-block; float: right; margin-top: 0px"></div>
<% else %> </td>
<td colspan="2" valign="top"> </tr>
<strong><%= link_to(h(e.user), user_path(e.user_id)) %></strong>&nbsp; <% when 'Principal' %>
<span class="font_lighter"><%= l(:label_new_activity) %></span>&nbsp; <tr>
<%= link_to format_activity_title("#{l(:label_news)}: #{act.title}"), {:controller => 'news', :action => 'show', :id => act.id} %> <% if e.user == User.current %>
</td> <td colspan="2" valign="top">
<% end %> <strong>
</tr> <%= link_to("#{l(:label_i)}", user_path(e.user_id)) %>
<tr> </strong>
<td colspan="2" width="580"> &nbsp;
<p class="font_description"> <%= textAreailizable act,:description %> </p></td> <span class="font_lighter">
</tr> <%= l(:label_new_user) %>
<tr> </span>
<td> </td>
<div style="display: inline-block; float: left; margin-top: 0px" width="200" align="right" class="a"> <% else %>
<span class="font_lighter"> <%= (l(:label_update_time).to_s << ':' << format_time(e.act.created_on)).to_s %></span> <td colspan="2" valign="top">
</div> <strong>
<div style="display: inline-block; float: right; margin-top: 0px"> <%= link_to(h(e.user), user_path(e.user_id)) %>
<span> </strong>
<%= link_to l(:label_find_all_comments), {:controller => 'news', :action => 'show', :id => act.id} %> &nbsp;
</span> <span class="font_lighter">
<a class="font_lighter"> <%= l(:label_new_user) %>
<%= l(:label_comments_count, :count => e.act.comments_count) %> </span>
</a> </td>
</div> <% end %>
</td> </tr>
</tr> <tr>
<% when 'Issue' %> <td colspan="2" width="580">
<tr> <p class="font_description"></p>
<% if e.user == User.current %> </td>
<td colspan="2" valign="top"> </tr>
<strong> <tr>
<%= link_to("#{l(:label_i)}", user_path(e.user_id)) %> <td>
</strong>&nbsp; <div style="display: inline-block; float: left; margin-top: 0px" width="200" align="right" class="a">
<span class="font_lighter"> <span class="font_lighter">
<%= l(:label_i_new_activity) %> <%= (l(:label_update_time).to_s << ':' << format_time(e.act.created_on)).to_s %>
</span>&nbsp; </span>
<%= link_to format_activity_title("#{act.source_from} (#{act.status}): #{act.tracker.name} #{act.subject}"), </div>
{:controller => 'issues', <div style="display: inline-block; float: right; margin-top: 0px"></div>
:action => 'show', </td>
:id => act.id} %> </tr>
</td> <% when 'News' %>
<% else %> <tr>
<td colspan="2" valign="top"> <% if e.user == User.current %>
<strong> <td colspan="2" valign="top">
<%= link_to(h(e.user), user_path(e.user_id)) %> <strong>
</strong>&nbsp; <%= link_to("#{l(:label_i)}", user_path(e.user_id)) %>
<span class="font_lighter"> </strong>
<%= l(:label_new_activity) %> &nbsp;
</span>&nbsp; <span class="font_lighter">
<%= link_to format_activity_title("#{act.source_from} (#{act.status}): #{act.tracker.name} #{act.subject}"), <%= l(:label_i_new_activity) %>
{:controller => 'issues', </span>
:action => 'show', &nbsp;
:id => act.id} %> <%= link_to format_activity_title("#{l(:label_news)}: #{act.title}"), {:controller => 'news', :action => 'show', :id => act.id} %>
</td> </td>
<% end %> <% else %>
</tr> <td colspan="2" valign="top">
<tr> <strong>
<td colspan="2" width="580" style="WORD-BREAK: break-all; WORD-WRAP: break-word"> <%= link_to(h(e.user), user_path(e.user_id)) %>
<%= textAreailizable act, :description %> </strong>
</td> &nbsp;
</tr> <span class="font_lighter">
<tr> <%= l(:label_new_activity) %>
<td> </span>
<div style="display: inline-block; float: left; margin-top: 0px" width="200" align="right" class="a"> &nbsp;
<span class="font_lighter"> <%= (l(:label_update_time).to_s << ':' << format_time(e.act.created_on)).to_s %></span> <%= link_to format_activity_title("#{l(:label_news)}: #{act.title}"), {:controller => 'news', :action => 'show', :id => act.id} %>
</div> </td>
<div style="display: inline-block; float: right; margin-top: 0px"> <% end %>
<span><%= link_to l(:label_find_all_comments), {:controller => 'issues', :action => 'show', :id => act.id} %></span> </tr>
<a class="font_lighter"><%= l(:label_comments_count, :count => e.act.journals.count) %></a> <tr>
</div> <td colspan="2" width="580">
</td> <p class="font_description">
</tr> <%= textAreailizable act,:description %>
<% when 'Contest' %> </p>
<tr> </td>
<% if e.user == User.current && @show_contest == 1%> </tr>
<td colspan="2" valign="top"> <tr>
<strong><%= link_to("#{l(:label_i)}", user_path(e.user_id)) %></strong>&nbsp; <td>
<span class="font_lighter"><%= l(:label_i_new_activity) %></span>&nbsp; <div style="display: inline-block; float: left; margin-top: 0px" width="200" align="right" class="a">
<%= link_to format_activity_title("#{l(:label_contest)}: #{act.name}"), {:controller => 'contests', :action => 'show_contest', :id => act.id} %> <span class="font_lighter">
</td> <%= (l(:label_update_time).to_s << ':' << format_time(e.act.created_on)).to_s %>
<% else %> </span>
<td colspan="2" valign="top"> </div>
<strong><%= link_to(h(e.user), user_path(e.user_id)) %></strong>&nbsp; <div style="display: inline-block; float: right; margin-top: 0px">
<span class="font_lighter"><%= l(:label_new_activity) %></span>&nbsp; <span>
<%= link_to format_activity_title("#{l(:label_contest)}: #{act.name}"), {:controller => 'contests', :action => 'show_contest', :id => act.id} %> <%= link_to l(:label_find_all_comments), {:controller => 'news', :action => 'show', :id => act.id} %>
</td> </span>
<% end %> <a class="font_lighter">
</tr> <%= l(:label_comments_count, :count => e.act.comments_count) %>
<tr> </a>
<td colspan="2" width="580"><p class="font_description"> <%= textAreailizable act, :description %> </p> </div>
</td> </td>
</tr> </tr>
<tr> <% when 'Issue' %>
<td> <tr>
<div style="display: inline-block; float: left; margin-top: 0px" width="200" align="right" class="a"> <% if e.user == User.current %>
<span class="font_lighter"> <%= (l(:label_update_time).to_s << ':' << format_time(e.act.created_on)).to_s %></span> <td colspan="2" valign="top">
</div> <strong>
</tr> <%= link_to("#{l(:label_i)}", user_path(e.user_id)) %>
<% else %> </strong>
<% end %><!-- < % #case end %> --> &nbsp;
<span class="font_lighter">
<%= l(:label_i_new_activity) %>
</span>&nbsp;
<%= link_to format_activity_title("#{act.source_from} (#{act.status}): #{act.tracker.name} #{act.subject}"),
{:controller => 'issues',
:action => 'show',
:id => act.id} %>
</td>
<% else %>
<td colspan="2" valign="top">
<strong>
<%= link_to(h(e.user), user_path(e.user_id)) %>
</strong>&nbsp;
<span class="font_lighter">
<%= l(:label_new_activity) %>
</span>&nbsp;
<%= link_to format_activity_title("#{act.source_from} (#{act.status}): #{act.tracker.name} #{act.subject}"),
{:controller => 'issues',
:action => 'show',
:id => act.id} %>
</td>
<% end %>
</tr>
<tr>
<td colspan="2" width="580" style="WORD-BREAK: break-all; WORD-WRAP: break-word">
<%= textAreailizable act, :description %>
</td>
</tr>
<tr>
<td>
<div style="display: inline-block; float: left; margin-top: 0px" width="200" align="right" class="a">
<span class="font_lighter">
<%= (l(:label_update_time).to_s << ':' << format_time(e.act.created_on)).to_s %>
</span>
</div>
<div style="display: inline-block; float: right; margin-top: 0px">
<span>
<%= link_to l(:label_find_all_comments), {:controller => 'issues', :action => 'show', :id => act.id} %>
</span>
<a class="font_lighter">
<%= l(:label_comments_count, :count => e.act.journals.count) %>
</a>
</div>
</td>
</tr>
<% when 'Contest' %>
<tr>
<% if e.user == User.current && @show_contest == 1%>
<td colspan="2" valign="top">
<strong>
<%= link_to("#{l(:label_i)}", user_path(e.user_id)) %>
</strong>
&nbsp;
<span class="font_lighter">
<%= l(:label_i_new_activity) %>
</span>
&nbsp;
<%= link_to format_activity_title("#{l(:label_contest)}: #{act.name}"), {:controller => 'contests', :action => 'show_contest', :id => act.id} %>
</td>
<% else %>
<td colspan="2" valign="top">
<strong>
<%= link_to(h(e.user), user_path(e.user_id)) %>
</strong>
&nbsp;
<span class="font_lighter">
<%= l(:label_new_activity) %>
</span>
&nbsp;
<%= link_to format_activity_title("#{l(:label_contest)}: #{act.name}"), {:controller => 'contests', :action => 'show_contest', :id => act.id} %>
</td>
<% end %>
</tr>
<tr>
<td colspan="2" width="580">
<p class="font_description">
<%= textAreailizable act, :description %>
</p>
</td>
</tr>
<tr>
<td>
<div style="display: inline-block; float: left; margin-top: 0px" width="200" align="right" class="a">
<span class="font_lighter">
<%= (l(:label_update_time).to_s << ':' << format_time(e.act.created_on)).to_s %>
</span>
</div>
</tr>
<% else %>
<% end %><!-- < % #case end %> -->
</table> </table>
</td> </td>
</tr> </tr>
@ -451,12 +583,19 @@
</td> </td>
</tr> </tr>
<tr> <tr>
<td colspan="2" width="580"><p class="font_description"> <%= textAreailizable e.notes %> </p></td> <td colspan="2" width="580">
<p class="font_description">
<%= textAreailizable e.notes %>
</p>
</td>
</tr> </tr>
<tr> <tr>
<td align="left"><a class="font_lighter"></a></td> <td align="left"><a class="font_lighter"></a></td>
<td width="200" align="right" class="a"> <td width="200" align="right" class="a">
<span class="font_lighter"><%= format_time e.created_on %></span></td> <span class="font_lighter">
<%= format_time e.created_on %>
</span>
</td>
</tr> </tr>
</table> </table>
</td> </td>
@ -466,11 +605,15 @@
</div> </div>
<div class="pagination" style="float:left;"> <div class="pagination" style="float:left;">
<ul> <%= pagination_links_full @info_pages %> </ul> <ul>
<%= pagination_links_full @info_pages %>
</ul>
</div> </div>
<% else %> <% else %>
<p class="font_description"><%= l(:label_no_user_respond_you) %></p> <p class="font_description">
<%= l(:label_no_user_respond_you) %>
</p>
<% end %> <% end %>

View File

@ -1,48 +1,72 @@
<!--modified by young--> <!--modified by young-->
<div class="contextual"> <div class="contextual" style="overflow: hidden;text-overflow: ellipsis;white-space: nowrap;">
<%= link_to(l(:button_edit), edit_version_path(@version), :class => 'icon icon-edit') if User.current.allowed_to?(:manage_versions, @version.project) %> <%= link_to(l(:button_edit), edit_version_path(@version), :class => 'icon icon-edit') if User.current.allowed_to?(:manage_versions, @version.project) %>
<%= link_to_if_authorized(l(:button_edit_associated_wikipage, :page_title => @version.wiki_page_title), {:controller => 'wiki', :action => 'edit', :project_id => @version.project, :id => Wiki.titleize(@version.wiki_page_title)}, :class => 'icon icon-edit') unless @version.wiki_page_title.blank? || @version.project.wiki.nil? %> <%= link_to_if_authorized(l(:button_edit_associated_wikipage,
<%= delete_link version_path(@version, :back_url => url_for(:controller => 'versions', :action => 'index', :project_id => @version.project)) if User.current.allowed_to?(:manage_versions, @version.project) %> :page_title => @version.wiki_page_title.truncate(30, omission: '...')),
{:controller => 'wiki',
:action => 'edit',
:project_id => @version.project,
:id => Wiki.titleize(@version.wiki_page_title)},
:class => 'icon icon-edit') unless @version.wiki_page_title.blank? || @version.project.wiki.nil? %>
<%= delete_link version_path(@version, :back_url => url_for(:controller => 'versions',
:action => 'index',
:project_id => @version.project)) if User.current.allowed_to?(:manage_versions, @version.project) %>
<%= call_hook(:view_versions_show_contextual, { :version => @version, :project => @project }) %> <%= call_hook(:view_versions_show_contextual, { :version => @version, :project => @project }) %>
</div> </div>
<h3><%= h(@version.name) %></h3> <h3 style="word-break: break-all;word-wrap: break-word;">
<%= h(@version.name) %>
</h3>
<div id="roadmap"> <div id="roadmap">
<%= render :partial => 'versions/overview', :locals => {:version => @version} %> <%= render :partial => 'versions/overview', :locals => {:version => @version} %>
<%= render(:partial => "wiki/content", :locals => {:content => @version.wiki_page.content}) if @version.wiki_page %> <%= render(:partial => "wiki/content", :locals => {:content => @version.wiki_page.content}) if @version.wiki_page %>
<div class="splitcontent"> <div class="splitcontent">
<% if @version.estimated_hours > 0 || User.current.allowed_to?(:view_time_entries, @project) %> <% if @version.estimated_hours > 0 || User.current.allowed_to?(:view_time_entries, @project) %>
<fieldset class="time-tracking"><legend><%= l(:label_time_tracking) %></legend> <fieldset class="time-tracking"><legend><%= l(:label_time_tracking) %></legend>
<table> <table>
<tr> <tr>
<th><%= l(:field_estimated_hours) %></th> <th>
<td class="total-hours"><%= html_hours(l_hours(@version.estimated_hours)) %></td> <%= l(:field_estimated_hours) %>
</tr> </th>
<% if User.current.allowed_to?(:view_time_entries, @project) %> <td class="total-hours">
<tr> <%= html_hours(l_hours(@version.estimated_hours)) %>
<th><%= l(:label_spent_time) %></th> </td>
<td class="total-hours"><%= html_hours(l_hours(@version.spent_hours)) %></td> </tr>
</tr> <% if User.current.allowed_to?(:view_time_entries, @project) %>
<% end %> <tr>
</table> <th>
</fieldset> <%= l(:label_spent_time) %>
<% end %> </th>
<td class="total-hours">
<%= html_hours(l_hours(@version.spent_hours)) %>
</td>
</tr>
<% end %>
</table>
</fieldset>
<% end %>
<div id="status_by" style="margin-top:10px;"><!--by young--> <div id="status_by" style="margin-top:10px;"><!--by young-->
<%= render_issue_status_by(@version, params[:status_by]) if @version.fixed_issues.count > 0 %> <%= render_issue_status_by(@version, params[:status_by]) if @version.fixed_issues.count > 0 %>
</div> </div>
</div> </div>
<% if @issues.present? %> <% if @issues.present? %>
<%= form_tag({}) do -%> <%= form_tag({}) do -%>
<table class="list related-issues"> <table class="list related-issues">
<caption><%= l(:label_related_issues) %></caption> <caption>
<%= l(:label_related_issues) %>
</caption>
<%- @issues.each do |issue| -%> <%- @issues.each do |issue| -%>
<tr class="hascontextmenu"> <tr class="hascontextmenu">
<td class="checkbox"><%= check_box_tag 'ids[]', issue.id, false, :id => nil %></td> <td class="checkbox">
<td><%= link_to_issue(issue, :project => (@project != issue.project)) %></td> <%= check_box_tag 'ids[]', issue.id, false, :id => nil %>
</td>
<td>
<%= link_to_issue(issue, :project => (@project != issue.project)) %>
</td>
</tr> </tr>
<% end %> <% end %>
</table> </table>

View File

@ -1,3 +1,4 @@
<<<<<<< HEAD
<%= wiki_page_breadcrumb(@page) %> <%= wiki_page_breadcrumb(@page) %>
<script src="http://<%= Setting.host_name%>/javascripts/ckeditor/ckeditor.js?1404953555" type="text/javascript"></script> <script src="http://<%= Setting.host_name%>/javascripts/ckeditor/ckeditor.js?1404953555" type="text/javascript"></script>
@ -60,3 +61,67 @@
<%= robot_exclusion_tag %> <%= robot_exclusion_tag %>
<% end %> <% end %>
<% html_title @page.pretty_title %> <% html_title @page.pretty_title %>
=======
<%= wiki_page_breadcrumb(@page) %>
<script src="http://<%= Setting.host_name%>/javascripts/ckeditor/ckeditor.js?1404953555" type="text/javascript"></script>
<h3 style="word-break: break-all;word-wrap: break-word;">
<%= h @page.pretty_title %>
</h3>
<%= form_for @content, :as => :content,
:url => {:action => 'update', :id => @page.title},
:html => {:method => :put, :multipart => true, :id => 'wiki_form'} do |f| %>
<%= f.hidden_field :version %>
<% if @section %>
<%= hidden_field_tag 'section', @section %>
<%= hidden_field_tag 'section_hash', @section_hash %>
<% end %>
<%= error_messages_for 'content' %>
<div class="actions" style="max-width:680px">
<p style="max-width:680px;">
<%=text_area_tag 'content[text]', @text, :required => true, :id => 'editor02', :cols => 100, :rows => 25 %>
</p>
<script type="text/javascript">
var ckeditor=CKEDITOR.replace('editor02',{height: '300'});
</script>
</div>
<div class="box tabular">
<% if @page.safe_attribute_names.include?('parent_id') && @wiki.pages.any? %>
<%= fields_for @page do |fp| %>
<p>
<label>
<%= l(:field_parent_title) %>
</label>
<%= fp.select :parent_id,content_tag('option', '', :value => '') + wiki_page_options_for_select(@wiki.pages.all(:include => :parent) - @page.self_and_descendants, @page.parent) %>
</p>
<% end %>
<% end %>
<p style="width: 100%;">
<label>
<%= l(:field_comments) %>
</label>
<%= f.text_field :comments, :style => "width:75%;" %>
</p>
<p>
<label>
<%=l(:label_attachment_plural)%>
</label>
<%= render :partial => 'attachments/form' %>
</p>
</div>
<p>
<%= submit_tag l(:button_save) %>
</p>
<%= wikitoolbar_for 'content_text' %>
<% end %>
<div id="preview" class="wiki"></div>
<% content_for :header_tags do %>
<%= robot_exclusion_tag %>
<% end %>
<% html_title @page.pretty_title %>
>>>>>>> d2f4b38eb6fd68a67940b8ffe735d8f7437acde1

View File

@ -2165,3 +2165,7 @@ zh:
lable_course_teacher: 主讲老师 lable_course_teacher: 主讲老师
lable_course_end: 课程学期已结束 lable_course_end: 课程学期已结束
lable_file_sharingarea: 资源共享区 lable_file_sharingarea: 资源共享区
label_no_contest_news_description: 竞赛描述不能为空
label_contest_news_condition: 竞赛描述超过5000个汉字
label_no_contest_news_title: 竞赛标题不能为空
label_contest_news_title_condition: 竞赛标题超过255个汉字