@@ -109,7 +110,7 @@
<%= form_tag(search_member_course_path,:id => "course_member_search_form", :method => :get, :class => "search_form_course",:remote => true) do %>
- <%= text_field_tag 'name', params[:name], :placeholder => "昵称、学号、姓名搜索", :class => "search_text fl" %>
+ <%= text_field_tag 'name', params[:name], :placeholder => "登录名、学号、姓名搜索", :class => "search_text fl" %>
<%= l(:label_search)%>
@@ -138,8 +139,6 @@
$('#ajax-modal').parent().css("top","").css("left","").css("border","3px solid #269ac9");
$('#ajax-modal').parent().addClass("anonymos");
}
- $("#time_selected").click(select);
- $("#term_selected").click(select);
- $("#end_time_selected").click(select);
- $("#end_term_selected").click(select);
+ $("#time").click(select);
+ $("#term").click(select);
diff --git a/app/views/homework_attach/_homeworks_list.html.erb b/app/views/homework_attach/_homeworks_list.html.erb
index c82a729de..2696bf9ec 100644
--- a/app/views/homework_attach/_homeworks_list.html.erb
+++ b/app/views/homework_attach/_homeworks_list.html.erb
@@ -20,7 +20,7 @@
<%= link_to l(:label_export_excel), get_batch_homeworks_homework_attach_index_path(:bid_id => @bid.id,:format => 'xls'),:class=>'xls' if is_batch_homeworks%>
<%= link_to l(:label_export_excel), get_not_batch_homework_homework_attach_index_path(:bid_id => @bid.id,:format => 'xls'),:class=>'xls' if not_batch_homework%>
<%= link_to l(:label_export_excel), get_homeworks_homework_attach_index_path(:bid_id => @bid.id,:format => 'xls'),:class=>'xls' if is_all_homeworks%>
-
+
搜索
diff --git a/app/views/issues/add_journal.js.erb b/app/views/issues/add_journal.js.erb
index eca7685cb..5708f6b3d 100644
--- a/app/views/issues/add_journal.js.erb
+++ b/app/views/issues/add_journal.js.erb
@@ -20,7 +20,7 @@
$(".homepagePostReplyBannerCount").html('回复(<%= Issue.find( @issue_id).journals.count %>)')
sd_create_editor_from_data(<%= @issue.id %>, null, "100%");
<%else%>
- $("#user_activity_<%= @user_activity_id %>").replaceWith("<%= escape_javascript(render :partial => 'users/project_issue', :locals => {:activity => @issue,:user_activity_id =>@user_activity_id}) %>");
+ $("#div_user_issue_reply_<%=@user_activity_id %>").replaceWith("<%= escape_javascript(render :partial => 'users/project_issue_reply', :locals => {:activity => @issue, :user_activity_id => @user_activity_id}) %>");
init_activity_KindEditor_data(<%= @user_activity_id %>,"","87%", 'UserActivity');
// sd_create_editor_from_data(<%#= @issue.id%>, null, "100%");
<%end %>
diff --git a/app/views/layouts/_project_info.html.erb b/app/views/layouts/_project_info.html.erb
index 60fc6f96d..9a9d34e54 100644
--- a/app/views/layouts/_project_info.html.erb
+++ b/app/views/layouts/_project_info.html.erb
@@ -3,14 +3,14 @@
<% student_num = studentCount(@course) %>
<% course_file_num = visable_attachemnts_incourse(@course).count%>
- <% if @course.id == 370 %>
+ <% if is_excellent_course(@course) %>
<% end %>
<%= image_tag(url_to_avatar(@course), :width => "60", :height => "60") %>
<%= @course.is_public == 0 ? "私有课程" : "公开课程" %>
- <% if @course.id == 370 %>
+ <% if is_excellent_course(@course) %>
<% end %>
diff --git a/app/views/layouts/base_courses.html.erb b/app/views/layouts/base_courses.html.erb
index 969e2643b..5f53e5203 100644
--- a/app/views/layouts/base_courses.html.erb
+++ b/app/views/layouts/base_courses.html.erb
@@ -199,12 +199,14 @@
-
<%= l(:label_tag)%>:
+
<%= l(:label_tag)%>:
<%= render :partial => 'tags/new_tag', :locals => {:obj => @course, :object_flag => "9"} %>
+
+ <%= render :partial => 'courses/recommendation', :locals => {:course => @course} %>
diff --git a/app/views/layouts/base_projects.html.erb b/app/views/layouts/base_projects.html.erb
index 880c6cc1c..657873f8b 100644
--- a/app/views/layouts/base_projects.html.erb
+++ b/app/views/layouts/base_projects.html.erb
@@ -150,7 +150,7 @@
-
<%= l(:label_tag)%>:
+
<%= l(:label_tag)%>:
<%= render :partial => 'tags/project_tag', :locals => {:obj => @project,:object_flag => "2"}%>
diff --git a/app/views/messages/_course_show.html.erb b/app/views/messages/_course_show.html.erb
index c3278a209..c760e686d 100644
--- a/app/views/messages/_course_show.html.erb
+++ b/app/views/messages/_course_show.html.erb
@@ -84,8 +84,8 @@
<%= @topic.content.html_safe%>
-
- <%= link_to_attachments_course @topic, :author => false %>
+
+ <%= render :partial=>"attachments/activity_attach", :locals=>{:activity => @topic} %>
diff --git a/app/views/messages/_org_subfield_show.html.erb b/app/views/messages/_org_subfield_show.html.erb
index 304694b39..6d12fe960 100644
--- a/app/views/messages/_org_subfield_show.html.erb
+++ b/app/views/messages/_org_subfield_show.html.erb
@@ -113,8 +113,8 @@
<%= @topic.content.html_safe%>
-
- <%= link_to_attachments_course @topic, :author => false %>
+
+ <%= render :partial=>"attachments/activity_attach", :locals=>{:activity => @topic} %>
diff --git a/app/views/messages/_project_show.html.erb b/app/views/messages/_project_show.html.erb
index e5aba7c02..c98f2983e 100644
--- a/app/views/messages/_project_show.html.erb
+++ b/app/views/messages/_project_show.html.erb
@@ -139,8 +139,8 @@
<%= @topic.content.html_safe%>
-
- <%= link_to_attachments_course @topic, :author => false %>
+
+ <%= render :partial=>"attachments/activity_attach", :locals=>{:activity => @topic} %>
diff --git a/app/views/news/_course_show.html.erb b/app/views/news/_course_show.html.erb
index 07aaef26d..767c11553 100644
--- a/app/views/news/_course_show.html.erb
+++ b/app/views/news/_course_show.html.erb
@@ -89,8 +89,8 @@
<%= @news.description.html_safe%>
-
- <%= link_to_attachments_course @news, :author => false %>
+
+ <%= render :partial=>"attachments/activity_attach", :locals=>{:activity => @news} %>
diff --git a/app/views/news/_organization_show.html.erb b/app/views/news/_organization_show.html.erb
index 98d14c3ab..3e608c177 100644
--- a/app/views/news/_organization_show.html.erb
+++ b/app/views/news/_organization_show.html.erb
@@ -79,8 +79,8 @@
<%= @news.description.html_safe%>
-
- <%= link_to_attachments_course @news, :author => false %>
+
+ <%= render :partial=>"attachments/activity_attach", :locals=>{:activity => @news} %>
diff --git a/app/views/news/_project_show.html.erb b/app/views/news/_project_show.html.erb
index 26ff807db..880bd0885 100644
--- a/app/views/news/_project_show.html.erb
+++ b/app/views/news/_project_show.html.erb
@@ -89,8 +89,8 @@
<%= @news.description.html_safe%>
-
- <%= link_to_attachments_course @news, :author => false %>
+
+ <%= render :partial=>"attachments/activity_attach", :locals=>{:activity => @news} %>
diff --git a/app/views/org_document_comments/show.html.erb b/app/views/org_document_comments/show.html.erb
index 26d04924a..405631369 100644
--- a/app/views/org_document_comments/show.html.erb
+++ b/app/views/org_document_comments/show.html.erb
@@ -29,8 +29,9 @@
<%= @document.content.html_safe %>
<% end %>
-
- <%= link_to_attachments_course @document, :author => false %>
+
+ <%= render :partial=>"attachments/activity_attach", :locals=>{:activity => @document} %>
+ <%#= link_to_attachments_course @document, :author => false %>
+
\ No newline at end of file
diff --git a/app/views/users/_project_issue_reply.html.erb b/app/views/users/_project_issue_reply.html.erb
new file mode 100644
index 000000000..0a84ba9c4
--- /dev/null
+++ b/app/views/users/_project_issue_reply.html.erb
@@ -0,0 +1,89 @@
+<% count = activity.journals.count %>
+
+
+
回复
+ <%= count>0 ? "(#{count})" : "" %>▪
+
+ <% if activity.author == User.current %>
+ 赞<%= get_praise_num(activity) > 0 ? "(#{get_praise_num(activity)})" : "" %>
+ <% else %>
+ <%=render :partial=> "praise_tread/praise", :locals => {:activity=>activity, :user_activity_id=>user_activity_id,:type=>"activity"}%>
+ <% end %>
+
+
+
<%#= format_date(activity.updated_on) %>
+ <% if count > 3 %>
+
+ <% end %>
+
+
+ <% replies_all_i = 0 %>
+ <% if count > 0 %>
+
+
+ <% activity.journals.reorder("created_on desc").each do |reply| %>
+
+ <% replies_all_i=replies_all_i + 1 %>
+ -
+
+ <%= link_to image_tag(url_to_avatar(reply.user), :width => "33", :height => "33"), user_path(reply.user_id), :alt => "用户头像" %>
+
+
+
+ <% if reply.try(:user).try(:realname) == ' ' %>
+ <%= link_to reply.try(:user), user_path(reply.user_id), :class => "newsBlue mr10 f14" %>
+ <% else %>
+ <%= link_to reply.try(:user).try(:realname), user_path(reply.user_id), :class => "newsBlue mr10 f14" %>
+ <% end %>
+ <%= format_time(reply.created_on) %>
+
+ <% if reply.user == User.current %>
+ 赞<%= get_praise_num(reply) > 0 ? "(#{get_praise_num(reply)})" : "" %>
+ <% else %>
+ <%=render :partial=> "praise_tread/praise", :locals => {:activity=>reply, :user_activity_id=>reply.id,:type=>"reply"}%>
+ <% end %>
+
+
+
+ <% if reply.details.any? %>
+ <% details_to_strings(reply.details).each do |string| %>
+
<%= string %>
+ <% end %>
+ <% end %>
+
<%= reply.notes.html_safe %>
+
+
+
+
+ <% end %>
+
+
+ <% end %>
+
+
+
<%= link_to image_tag(url_to_avatar(User.current), :width => "33", :height => "33"), user_path(activity.author_id), :alt => "用户头像" %>
+
+
+ <%= form_for('new_form',:url => add_journal_issue_path(activity.id, :user_activity_id => user_activity_id),:method => "post", :remote => true) do |f| %>
+
+
+
+
发送
+
+
+ <% end%>
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/app/views/users/_user_homework_detail.html.erb b/app/views/users/_user_homework_detail.html.erb
index b3e14d174..04c8b8f0a 100644
--- a/app/views/users/_user_homework_detail.html.erb
+++ b/app/views/users/_user_homework_detail.html.erb
@@ -156,7 +156,9 @@
<% break %>
<% end %>
<% end %>
- <%= link_to "更多>>", student_work_index_path(:homework => homework_common.id),:class=>'linkGrey2 fl ml50',:style=>'margin-top:60px;'%>
+ <% if student_works.count > 5%>
+ <%= link_to "更多>>", student_work_index_path(:homework => homework_common.id),:class=>'linkGrey2 fl ml50',:style=>'margin-top:60px;'%>
+ <% end %>
<% end %>
@@ -189,10 +191,11 @@
<% else %>
<%= image_tag(url_to_avatar(project),:width=>"40",:height => "40",:class => "borderRadius",:id=>"project_img_"+project.id.to_s+"_"+homework_common.id.to_s,:alt =>"项目头像") %>
<% end %>
+ <% com_time = project.project_score.commit_time %>
<% time=project.updated_on %>
<% time=ForgeActivity.where("project_id=?",project.id).last.updated_at if ForgeActivity.where("project_id=?",project.id).last %>
<%=(User.find project.user_id).show_name %>(组长)
- <%=time_from_now time %> <%= project.project_score.changeset_num %>提交
+ <%=time_from_now !com_time.nil? && format_time(com_time) > format_timetime ? com_time : time %> <%= project.project_score.changeset_num %>提交
项目名称:<%=project.name %>
创建者:<%=(User.find project.user_id).show_name %>(组长)
diff --git a/app/views/welcome/_search_project.html.erb b/app/views/welcome/_search_project.html.erb
index 6679f559d..fba855bde 100644
--- a/app/views/welcome/_search_project.html.erb
+++ b/app/views/welcome/_search_project.html.erb
@@ -91,7 +91,7 @@ form #search_by
{
if($("#search_type").val() == "users")
{
- $("#q").attr('placeholder','昵称/姓名/邮箱');
+ $("#q").attr('placeholder','登录名/姓名/邮箱');
// $("#search_by").show();
}
else
diff --git a/config/locales/navigatiors/zh.yml b/config/locales/navigatiors/zh.yml
index 97c6da61a..c0df616f3 100644
--- a/config/locales/navigatiors/zh.yml
+++ b/config/locales/navigatiors/zh.yml
@@ -63,7 +63,7 @@ zh:
course: 课程
user: 用户
userinfo:
- nickname: 昵称
+ nickname: 登录名
showname: 姓名
email: 邮箱
diff --git a/config/locales/projects/zh.yml b/config/locales/projects/zh.yml
index 765060675..8bf3f03be 100644
--- a/config/locales/projects/zh.yml
+++ b/config/locales/projects/zh.yml
@@ -369,7 +369,7 @@ zh:
label_input_email: 请输入邮箱地址
label_invite_trustie_user: "邀请Trustie注册用户"
- label_invite_trustie_user_tips: "支持姓名、邮箱、昵称搜索!"
+ label_invite_trustie_user_tips: "支持姓名、邮箱、登录名搜索!"
label_user_role_null: 用户和角色不能留空!
label_invite_project: 邀请您加入项目
label_mail_invite_success: 您已成功加入项目!
diff --git a/config/locales/zh.yml b/config/locales/zh.yml
index 34a526734..daa0c3a31 100644
--- a/config/locales/zh.yml
+++ b/config/locales/zh.yml
@@ -1855,7 +1855,7 @@ zh:
excel_user_id: 学生id
excel_user_name: 用户名
- excel_nickname: 昵称
+ excel_nickname: 登录名
excel_student_id: 学号
excel_mail: 电子邮箱
excel_homework_name: 作品名
@@ -2106,4 +2106,6 @@ zh:
label_org_name: 组织名称:
label_blank_user_lists_for_org: 用户不能为空
-
+ # 课程推荐
+ label_homework_commont: 作业
+ label_homework_recommendation: 课程推荐
\ No newline at end of file
diff --git a/config/routes.rb b/config/routes.rb
index 3531f4b5f..148b6dea2 100644
--- a/config/routes.rb
+++ b/config/routes.rb
@@ -525,6 +525,7 @@ RedmineApp::Application.routes.draw do
match 'file_score_index', :to => 'projects#file_score_index', :via => [:get, :post]
match 'code_submit_score_index', :to => 'projects#code_submit_score_index', :via => [:get, :post]
match 'projects_topic_score_index', :to => 'projects#projects_topic_score_index', :via => [:get, :post]
+ match 'user_act_issue_assign_to', :to => 'users#user_act_issue_assign_to', :via => [:get, :post]
get 'edit_brief_introduction'
get "user_resource"
get "resource_search"
diff --git a/db/migrate/20160115021923_add_is_excellent_to_course.rb b/db/migrate/20160115021923_add_is_excellent_to_course.rb
new file mode 100644
index 000000000..39bbf2dd5
--- /dev/null
+++ b/db/migrate/20160115021923_add_is_excellent_to_course.rb
@@ -0,0 +1,5 @@
+class AddIsExcellentToCourse < ActiveRecord::Migration
+ def change
+ add_column :courses, :is_excellent, :integer, :default => false
+ end
+end
diff --git a/db/migrate/20160115022341_add_excellent_course.rb b/db/migrate/20160115022341_add_excellent_course.rb
new file mode 100644
index 000000000..6d743d0c3
--- /dev/null
+++ b/db/migrate/20160115022341_add_excellent_course.rb
@@ -0,0 +1,7 @@
+class AddExcellentCourse < ActiveRecord::Migration
+ def up
+ end
+
+ def down
+ end
+end
diff --git a/db/migrate/20160118014219_define_excellent_course.rb b/db/migrate/20160118014219_define_excellent_course.rb
new file mode 100644
index 000000000..911c14a3e
--- /dev/null
+++ b/db/migrate/20160118014219_define_excellent_course.rb
@@ -0,0 +1,17 @@
+class DefineExcellentCourse < ActiveRecord::Migration
+ def up
+ arr = [302,192,370,394,183,361,117,218,379,178,418,203,342,403,225]
+ for i in 0..arr.length-1
+ begin
+ puts arr[i]
+ course = Course.find(arr[i])
+ course.update_attribute(:is_excellent, true)
+ rescue
+ logger.error("Course is not found!")
+ end
+ end
+ end
+
+ def down
+ end
+end
\ No newline at end of file
diff --git a/db/migrate/20160118083751_add_status_to_message.rb b/db/migrate/20160118083751_add_status_to_message.rb
new file mode 100644
index 000000000..46d63de3a
--- /dev/null
+++ b/db/migrate/20160118083751_add_status_to_message.rb
@@ -0,0 +1,5 @@
+class AddStatusToMessage < ActiveRecord::Migration
+ def change
+ add_column :messages, :status, :integer, :default => false
+ end
+end
diff --git a/db/migrate/20160122023014_add_commit_time.rb b/db/migrate/20160122023014_add_commit_time.rb
new file mode 100644
index 000000000..d9b860073
--- /dev/null
+++ b/db/migrate/20160122023014_add_commit_time.rb
@@ -0,0 +1,27 @@
+class AddCommitTime < ActiveRecord::Migration
+ def up
+ add_column :project_scores, :commit_time, :datetime, :default => nil
+ count = ProjectScore.all.count / 30 + 2
+ transaction do
+ for i in 1 ... count do i
+ ProjectScore.page(i).per(30).each do |ps|
+ unless ps.project.nil?
+ unless ps.project.gpid.nil?
+ g = Gitlab.client
+ begin
+ changesets = g.commits(ps.project.gpid)
+ ps.commit_time = changesets[0].created_at
+ ps.save
+ rescue
+ logger.error("The project's rep is not exit!")
+ end
+ end
+ end
+ end
+ end
+ end
+ end
+
+ def down
+ end
+end
diff --git a/db/migrate/20160122083400_add_excellent_option_to_course.rb b/db/migrate/20160122083400_add_excellent_option_to_course.rb
new file mode 100644
index 000000000..560153781
--- /dev/null
+++ b/db/migrate/20160122083400_add_excellent_option_to_course.rb
@@ -0,0 +1,6 @@
+class AddExcellentOptionToCourse < ActiveRecord::Migration
+ def change
+ add_column :courses, :excellent_option, :integer, :default => false
+ end
+end
+
diff --git a/db/migrate/20160122083507_define_excellent_option_course.rb b/db/migrate/20160122083507_define_excellent_option_course.rb
new file mode 100644
index 000000000..7b4a4ae4a
--- /dev/null
+++ b/db/migrate/20160122083507_define_excellent_option_course.rb
@@ -0,0 +1,19 @@
+class DefineExcellentOptionCourse < ActiveRecord::Migration
+ def up
+ arr = [151,122,15,227,139,410,291,224,55,137,414,43,417,52,205,44,216,132,204,258,411,50,
+ 419,390,420,133,91,112,202,95,194,34,172,403,177,252,138,352,225,46,279,382,397,286,344,27,175,
+ 124,265,88,59,110,72,92,392,413,26,201,94,57,156,393,154,12,262]
+ for i in 0..arr.length-1
+ begin
+ puts arr[i]
+ course = Course.find(arr[i])
+ course.update_attribute(:excellent_option, true)
+ rescue
+ logger.error("Course is not found!")
+ end
+ end
+ end
+
+ def down
+ end
+end
diff --git a/db/schema.rb b/db/schema.rb
index 347f801a6..7e6291806 100644
--- a/db/schema.rb
+++ b/db/schema.rb
@@ -11,7 +11,7 @@
#
# It's strongly recommended to check this file into your version control system.
-ActiveRecord::Schema.define(:version => 20160121070232) do
+ActiveRecord::Schema.define(:version => 20160122083507) do
create_table "activities", :force => true do |t|
t.integer "act_id", :null => false
@@ -499,6 +499,8 @@ ActiveRecord::Schema.define(:version => 20160121070232) do
t.integer "is_delete", :default => 0
t.integer "end_time"
t.string "end_term"
+ t.integer "is_excellent", :default => 0
+ t.integer "excellent_option", :default => 0
end
create_table "custom_fields", :force => true do |t|
@@ -1072,6 +1074,7 @@ ActiveRecord::Schema.define(:version => 20160121070232) do
t.integer "sticky", :default => 0
t.integer "reply_id"
t.integer "quotes"
+ t.integer "status", :default => 0
end
add_index "messages", ["author_id"], :name => "index_messages_on_author_id"
@@ -1214,7 +1217,6 @@ ActiveRecord::Schema.define(:version => 20160121070232) do
create_table "org_members", :force => true do |t|
t.integer "user_id"
t.integer "organization_id"
- t.string "role"
t.datetime "created_at", :null => false
t.datetime "updated_at", :null => false
end
@@ -1712,10 +1714,6 @@ ActiveRecord::Schema.define(:version => 20160121070232) do
t.string "extra"
end
- create_table "temp", :id => false, :force => true do |t|
- t.integer "id", :default => 0, :null => false
- end
-
create_table "time_entries", :force => true do |t|
t.integer "project_id", :null => false
t.integer "user_id", :null => false
diff --git a/public/javascripts/course.js b/public/javascripts/course.js
index 6c2f0af71..fff30dec5 100644
--- a/public/javascripts/course.js
+++ b/public/javascripts/course.js
@@ -193,7 +193,7 @@ function submit_new_course()
function submit_edit_course(id)
{
- if(regex_course_name()&®ex_course_class_period()&®ex_course_password())
+ if(regex_course_name()&®ex_course_class_period()&®ex_time_term()&®ex_course_password())
{
$("#edit_course_"+id).submit();
}
diff --git a/public/stylesheets/courses.css b/public/stylesheets/courses.css
index 810cd0fec..1e3c68c83 100644
--- a/public/stylesheets/courses.css
+++ b/public/stylesheets/courses.css
@@ -95,6 +95,7 @@ a.hworkSearchIcon:hover {background:url(../images/nav_icon.png) -49px -1px no-re
.mt-2 {margin-top:-2px;}
.homeworkInfo {background:#F6F6F6; padding:10px; margin-bottom:10px;}
.homeworkDetail {line-height:18px; font-size:12px; color:#484848; overflow:hidden;}
+.homeworkDetail p,.homeworkDetail div,.homeworkDetail em, .homeworkDetail span{text-align: justify; text-justify:inter-ideograph; word-break: normal !important; word-wrap: break-word !important; line-height: 18px !important;}
.max_h54 {max-height:54px; }
.homeworkState {padding:3px 5px; background-color:#28be6c; border-radius:3px; float:left; margin-left:15px; color:#ffffff;}
.homeworkClose {padding:3px 5px; background-color:#b2b2b2; border-radius:3px; float:left; margin-left:15px; color:#ffffff;}
@@ -1259,4 +1260,5 @@ div.disable_link {background-color: #c1c1c1 !important;}
.boutiqueP {position:absolute; left:0px; top:0px;}
.mh18 {max-height: 18px;}
-.relatePWrap{max-height: 210px;overflow:hidden;}
+.relatePWrap{max-height: 210px;overflow:hidden;}/*160114课程推荐*/
+.courseR {width:220px; padding:10px; background-color:#ffffff; margin-top:10px;}
diff --git a/public/stylesheets/new_user.css b/public/stylesheets/new_user.css
index b1f950960..26bf53c62 100644
--- a/public/stylesheets/new_user.css
+++ b/public/stylesheets/new_user.css
@@ -1422,3 +1422,14 @@ span.at a{color:#269ac9;text-decoration: none;}
.orgSendSearch {border:1px solid #dddddd; outline:none; width:262px; height:22px; padding-left:10px; float:left;}
.relatePWrap{max-height: 210px;overflow:hidden;}
+
+/*20160115问题跟踪*/
+.proInfoBox2{ border:1px solid #dddddd; height:45px; padding:10px 0; background-color:#f1f1f1;}
+.proInfoBox2 ul li{ height:24px; position:relative;}
+.pic_edit2{display:inline-block; background:url(../images/public_icon.png) 0px -32px no-repeat; width:20px; height:15px; vertical-align:middle; display:none;}
+.pic_edit2:hover{display:inline-block; background:url(../images/public_icon.png) -32px -32px no-repeat; width:20px; height:15px;}
+.w70{ width:70px;}
+.w80{ width:80px;}
+.label03{ width:70px; text-align:right; display:block; float:left;}
+.pro_info_p{color:#0781b4 !important; float:left; width:80px; overflow:hidden; white-space: nowrap; text-overflow:ellipsis; }
+.proInfoP{color:#000000 !important; float:left; width:80px; overflow:hidden; white-space: nowrap; text-overflow:ellipsis; }
\ No newline at end of file
diff --git a/public/stylesheets/project.css b/public/stylesheets/project.css
index c671f30ec..f1b0c5846 100644
--- a/public/stylesheets/project.css
+++ b/public/stylesheets/project.css
@@ -1163,4 +1163,8 @@ a.uploadIcon {background:url(images/resource_icon_list.png) 8px -60px no-repeat;
.mb10 {margin-bottom: 10px}
.mb15 {margin-bottom: 15px}
div.disable_link {background-color: #c1c1c1 !important;}
-.reUploadDetail{border:1px solid #dddddd; float:left; resize:none; width:400px; height:80px; overflow-y:auto;outline: none;}
\ No newline at end of file
+.reUploadDetail{border:1px solid #dddddd; float:left; resize:none; width:400px; height:80px; overflow-y:auto;outline: none;}
+
+/*问题跟踪局部修改属性*/
+.proInfoBox2{ border:1px solid #dddddd; height:45px; padding:10px 0; background-color:#f1f1f1;}
+.proInfoBox2 ul li{ height:24px; position:relative;}
diff --git a/public/stylesheets/public.css b/public/stylesheets/public.css
index 79b441f25..abd2c10f9 100644
--- a/public/stylesheets/public.css
+++ b/public/stylesheets/public.css
@@ -140,10 +140,12 @@ h4{ font-size:14px; color:#3b3b3b;}
.w50 {width:50px;}
.w60{ width:60px;}
.w70{ width:70px;}
+.w80{ width:80px;}
.w90{ width:90px;}
.w100{width: 100px;}
.w210{ width:210px;}
.w150{ width:150px;}
+.w170{width:170px;}
.w230{width:230px !important;}
.w235{ width:235px !important;}
.w280{ width:280px;}
@@ -170,6 +172,7 @@ h4{ font-size:14px; color:#3b3b3b;}
.h70{ height:70px;}
.h150{ height:150px;}
.p10 {padding-left:10px; padding-right:10px;}
+.mw360 {max-width: 360px !important;}
.mw400 {max-width: 400px !important;}
.mh18 {max-height: 18px;}
@@ -220,6 +223,7 @@ a.c_green{ color:#28be6c;}
.fontGrey {color:#cecece;}
.fontGrey2 {color:#888888;}
.fontGrey3 {color:#484848;}
+.fontGrey4{color:#999999;}
.fontBlue {color:#3498db;}
a.underline {text-decoration:underline;}
a.fontBlue {color:#297fb8;}
@@ -321,6 +325,9 @@ a:hover.bgreen_n_btn{background:#08a384;}
.pic_text02{display:block; background:url(../images/new_project/public_icon.png) 0px -642px no-repeat; width:20px; height:19px;}
.pic_edit{display:block; background:url(../images/new_project/public_icon.png) 0px -32px no-repeat; width:20px; height:15px;}
.pic_edit:hover{display:block; background:url(../images/new_project/public_icon.png) -32px -32px no-repeat; width:20px; height:15px;}
+.pic_edit2{display:inline-block; background:url(../images/public_icon.png) 0px -32px no-repeat; width:20px; height:15px; vertical-align:middle; display:none;}
+.pic_edit2:hover{display:inline-block; background:url(../images/public_icon.png) -32px -32px no-repeat; width:20px; height:15px;}
+