diff --git a/app/controllers/my_controller.rb b/app/controllers/my_controller.rb
index e83a160c5..0aba4ed26 100644
--- a/app/controllers/my_controller.rb
+++ b/app/controllers/my_controller.rb
@@ -77,7 +77,7 @@ class MyController < ApplicationController
# ue.save
# end
- # added by bai 往数据库里写职业、性别和地区
+ # added by bai 寰鏁版嵁搴撻噷鍐欒亴涓氥佹у埆鍜屽湴鍖
if @user.user_extensions.nil?
se = UserExtensions.new
se.user_id = @user.id
@@ -89,7 +89,9 @@ class MyController < ApplicationController
se = @user.user_extensions
se.occupation = params[:occupation]
se.gender = params[:gender]
+ if params[:province] && params[:city]
se.location = params[:province]+params[:city]
+ end
se.save
end
# end
diff --git a/app/controllers/projects_controller.rb b/app/controllers/projects_controller.rb
index 6a07c5c84..9ad847dde 100644
--- a/app/controllers/projects_controller.rb
+++ b/app/controllers/projects_controller.rb
@@ -192,7 +192,7 @@ class ProjectsController < ApplicationController
@projects = []
@projects_status.each do |obj|
- @projects << Project.find_by_id("#{obj.project_id}")
+ @projects << Project.visible.find_by_id("#{obj.project_id}") unless Project.visible.find_by_id("#{obj.project_id}").nil?
end
#end
respond_to do |format|
@@ -366,7 +366,9 @@ class ProjectsController < ApplicationController
r = Role.givable.find_by_id(Setting.new_project_user_role_id.to_i) || Role.givable.first
m = Member.new(:user => User.current, :roles => [r])
project = ProjectInfo.new(:user_id => User.current.id, :project_id => @project.id)
- project_status = ProjectStatus.create(:project_id => @project.id)
+ if params[:project][:is_public] == 1
+ project_status = ProjectStatus.create(:project_id => @project.id, :watchers_count => 0, :changesets_count => 0)
+ end
@project.members << m
@project.project_infos << project
end
@@ -435,7 +437,7 @@ class ProjectsController < ApplicationController
@subprojects = @project.children.visible.all
@news = @project.news.limit(5).includes(:author, :project).reorder("#{News.table_name}.created_on DESC").all
@trackers = @project.rolled_up_trackers
- @user = User.find_by_id(ProjectInfo.find_by_project_id(@project.id).user_id)
+ @user = User.find_by_id(ProjectInfo.find_by_project_id(@project.id).user_id)
cond = @project.project_condition(Setting.display_subprojects_issues?)
@open_issues_by_tracker = Issue.visible.open.where(cond).count(:group => :tracker)
@@ -562,6 +564,14 @@ class ProjectsController < ApplicationController
@course.term = params[:project][:course][:term]
@course.save
@project.set_allowed_parent!(params[:project]['parent_id']) if params[:project].has_key?('parent_id')
+
+ if params[:project][:is_public] == '0'
+ project_status = ProjectStatus.find_by_project_id(@project.id)
+ project_status.destroy
+ elsif params[:project][:is_public] == '1'
+ project_status = ProjectStatus.create(:project_id => @project.id, :watchers_count => 0, :changesets_count => 0)
+ end
+
respond_to do |format|
format.html {
flash[:notice] = l(:notice_successful_update)
diff --git a/app/helpers/projects_helper.rb b/app/helpers/projects_helper.rb
index b23d1174c..1b8340721 100644
--- a/app/helpers/projects_helper.rb
+++ b/app/helpers/projects_helper.rb
@@ -94,11 +94,11 @@ module ProjectsHelper
def render_project_hierarchy(projects)
render_project_nested_lists(projects) do |project|
#Modified by young
- if (project.project_type==1)
- s = link_to_project(project, {}, :class => "#{project.css_classes} #{User.current.member_of?(project) ? 'my-project' : nil}")+"(#{l(:label_course)})".html_safe
- else
- s = link_to_project(project, {}, :class => "#{project.css_classes} #{User.current.member_of?(project) ? 'my-project' : nil}")
- end
+ if (project.project_type==1)
+ s = link_to_project(project, {}, :class => "#{project.css_classes} #{User.current.member_of?(project) ? 'my-project' : nil}")+"(#{l(:label_course)})".html_safe
+ else
+ s = link_to_project(project, {}, :class => "#{project.css_classes} #{User.current.member_of?(project) ? 'my-project' : nil}")
+ end
#Ended by young
if project.description.present?
#Delete by nie.
diff --git a/app/helpers/users_helper.rb b/app/helpers/users_helper.rb
index a1befebc7..c813714d3 100644
--- a/app/helpers/users_helper.rb
+++ b/app/helpers/users_helper.rb
@@ -64,9 +64,9 @@ module UsersHelper
# added by fq
#
def show_activity(state)
diff --git a/app/models/project.rb b/app/models/project.rb
index 3a95ff603..27cb9bb8c 100644
--- a/app/models/project.rb
+++ b/app/models/project.rb
@@ -64,6 +64,7 @@ class Project < ActiveRecord::Base
has_many :project_infos, :dependent => :destroy
has_one :project_status, :class_name => "ProjectStatus", :dependent => :destroy
has_one :project_status, :class_name => "ProjectStatus", :dependent => :destroy
+ has_one :project_status, :class_name => "ProjectStatus", :dependent => :destroy
#end
has_one :wiki, :dependent => :destroy
diff --git a/app/models/user.rb b/app/models/user.rb
index 93f4cb83c..58b33551b 100644
--- a/app/models/user.rb
+++ b/app/models/user.rb
@@ -88,6 +88,7 @@ class User < Principal
has_many :courses, :through => :students_for_courses, :source => :project
has_many :acts, :class_name => 'Activity', :as => :act, :dependent => :destroy
has_many :acts, :class_name => 'Activity', :as => :act, :dependent => :destroy
+ has_many :acts, :class_name => 'Activity', :as => :act, :dependent => :destroy
#####
######added by nie
diff --git a/app/views/account/register.html.erb b/app/views/account/register.html.erb
index 1f09ba6ab..ce666940e 100644
--- a/app/views/account/register.html.erb
+++ b/app/views/account/register.html.erb
@@ -1,4 +1,4 @@
-
+
-->
-<%= l(:label_location) %>
<% if Setting.openid? %>
diff --git a/app/views/projects/_form.html.erb b/app/views/projects/_form.html.erb
index e2c990915..2ccd84032 100644
--- a/app/views/projects/_form.html.erb
+++ b/app/views/projects/_form.html.erb
@@ -16,6 +16,7 @@
<%= wikitoolbar_for 'project_description' %>
+
<% @project.custom_field_values.each do |value| %>
<%= custom_field_tag_with_label :project, value %>
<% end %>
diff --git a/app/views/projects/_new_respond.html.erb b/app/views/projects/_new_respond.html.erb
index 0db0ecf21..9daa48e14 100644
--- a/app/views/projects/_new_respond.html.erb
+++ b/app/views/projects/_new_respond.html.erb
@@ -1,8 +1,8 @@
-<%= form_tag({:controller => 'projects',
-:action => 'project_respond'}) do %>
-<%= text_area_tag 'project_respond', "", :class => 'noline', :required => true, :style => "resize: none;", :rows => 6, :placeholder => l(:label_projects_feedback_respond_content) %>
-
-<%= hidden_field_tag 'reference_id', params[:reference_id], :value => journal.id %>
-<%= submit_tag l(:button_projects_feedback_respond), :name => nil , :class => "bid_btn"%>
-
-<%end%>
+<%= form_tag({:controller => 'projects',
+:action => 'project_respond'}) do %>
+<%= text_area_tag 'project_respond', "", :class => 'noline', :required => true, :style => "resize: none;", :rows => 6, :placeholder => l(:label_projects_feedback_respond_content) %>
+
+<%= hidden_field_tag 'reference_id', params[:reference_id], :value => journal.id %>
+<%= submit_tag l(:button_projects_feedback_respond), :name => nil , :class => "bid_btn"%>
+
+<%end%>
diff --git a/app/views/projects/_project.html.erb b/app/views/projects/_project.html.erb
index 8dbeb11ae..8042cfe4d 100644
--- a/app/views/projects/_project.html.erb
+++ b/app/views/projects/_project.html.erb
@@ -19,7 +19,7 @@
<%= content_tag('span', "#{(@project.repository.nil? || @project.repository.changesets[0].nil?) ? '0' : distance_of_time_in_words(Time.now, @project.repository.changesets[0].committed_on)}", :class => "info") %><%= content_tag('span', l(:label_since_last_commits)) %>
- <%= content_tag('span', "#{@project.repository.nil? ? '0' : @project.repository.changesets.count }", :class => "info") %><%= content_tag('span', l(:label_commit_on)) %>
+ <%= content_tag('span', "#{@project.repository.nil? ? '0' : @project.project_status.changesets_count }", :class => "info") %><%= content_tag('span', l(:label_commit_on)) %>
@@ -35,7 +35,7 @@
<% @admin = @project.project_infos%>
<% if @admin.size > 0 %>
- <%= content_tag('a', @admin.collect{|u| link_to(u.user.name, user_path(u.user_id))}.join(", ").html_safe) %>
+ <%= content_tag('a', @admin.collect{|u| link_to(u.user.name, user_path(u.user_id))}.join(", ").html_safe) %>
<% end %>
diff --git a/app/views/projects/index.html.erb b/app/views/projects/index.html.erb
index d354aa12a..11c44ee01 100644
--- a/app/views/projects/index.html.erb
+++ b/app/views/projects/index.html.erb
@@ -50,6 +50,22 @@
-->
+<%= sort_project(@s_type)%>
+
+
+
<%= render_project_hierarchy(@projects)%>
diff --git a/db/migrate/20130828004955_stored_status_procedure.rb b/db/migrate/20130828004955_stored_status_procedure.rb
index 91b37ecd2..29a752765 100644
--- a/db/migrate/20130828004955_stored_status_procedure.rb
+++ b/db/migrate/20130828004955_stored_status_procedure.rb
@@ -34,7 +34,7 @@ begin
declare v_uid bigint(22);
declare v int(10);
declare _done TINYINT(1) default 0;
- declare cur_user cursor for select project_id,count(*) from (select project_id,repositories.id from repositories inner join changesets where repositories.id = changesets.repository_id)t group by project_id;
+ declare cur_user cursor for select project_id,count(*) from (select project_id,repositories.id from repositories inner join changesets where repositories.id = changesets.repository_id and project_id in (SELECT `projects`.id FROM `projects` WHERE (((projects.status <> 9) AND (projects.is_public = 1)))))t group by project_id;
declare continue handler for not found set _done = 1;
open cur_user;
loop_xxx:loop
diff --git a/db/schema.rb b/db/schema.rb
index b8ca66994..3189f6c12 100644
--- a/db/schema.rb
+++ b/db/schema.rb
@@ -13,14 +13,6 @@
ActiveRecord::Schema.define(:version => 20130918004629) do
- create_table "a_user_watchers", :force => true do |t|
- t.string "name"
- t.text "description"
- t.datetime "created_at", :null => false
- t.datetime "updated_at", :null => false
- t.integer "member_id"
- end
-
create_table "activities", :force => true do |t|
t.integer "act_id", :null => false
t.string "act_type", :null => false
@@ -77,7 +69,6 @@ ActiveRecord::Schema.define(:version => 20130918004629) do
t.string "description"
t.datetime "created_at", :null => false
t.datetime "updated_at", :null => false
- t.integer "reward"
end
create_table "bids", :force => true do |t|
@@ -284,9 +275,9 @@ ActiveRecord::Schema.define(:version => 20130918004629) do
add_index "issue_categories", ["project_id"], :name => "issue_categories_project_id"
create_table "issue_relations", :force => true do |t|
- t.integer "issue_from_id", :null => false
- t.integer "issue_to_id", :null => false
- t.string "relation_type", :null => false
+ t.integer "issue_from_id", :null => false
+ t.integer "issue_to_id", :null => false
+ t.string "relation_type", :default => "", :null => false
t.integer "delay"
end
@@ -428,22 +419,6 @@ ActiveRecord::Schema.define(:version => 20130918004629) do
add_index "messages", ["last_reply_id"], :name => "index_messages_on_last_reply_id"
add_index "messages", ["parent_id"], :name => "messages_parent_id"
- create_table "messages_for_bids", :force => true do |t|
- t.string "message"
- t.integer "user_id"
- t.integer "bid_id"
- t.datetime "created_at", :null => false
- t.datetime "updated_at", :null => false
- end
-
- create_table "messages_for_users", :force => true do |t|
- t.integer "messager_id"
- t.integer "user_id"
- t.string "message"
- t.datetime "created_at", :null => false
- t.datetime "updated_at", :null => false
- end
-
create_table "news", :force => true do |t|
t.integer "project_id"
t.string "title", :limit => 60, :default => "", :null => false
@@ -504,18 +479,6 @@ ActiveRecord::Schema.define(:version => 20130918004629) do
t.integer "project_id"
end
- add_index "project_statuses", ["changesets_count"], :name => "index_project_statuses_on_changesets_count"
- add_index "project_statuses", ["watchers_count"], :name => "index_project_statuses_on_watchers_count"
-
- create_table "project_tags", :force => true do |t|
- t.integer "project_id"
- t.integer "tag_id"
- t.string "description"
- t.datetime "created_at", :null => false
- t.datetime "updated_at", :null => false
- t.integer "user_id"
- end
-
create_table "projects", :force => true do |t|
t.string "name", :default => "", :null => false
t.text "description"
@@ -583,6 +546,26 @@ ActiveRecord::Schema.define(:version => 20130918004629) do
t.string "issues_visibility", :limit => 30, :default => "default", :null => false
end
+ create_table "seems_rateable_cached_ratings", :force => true do |t|
+ t.integer "cacheable_id", :limit => 8
+ t.string "cacheable_type"
+ t.float "avg", :null => false
+ t.integer "cnt", :null => false
+ t.string "dimension"
+ t.datetime "created_at", :null => false
+ t.datetime "updated_at", :null => false
+ end
+
+ create_table "seems_rateable_rates", :force => true do |t|
+ t.integer "rater_id", :limit => 8
+ t.integer "rateable_id"
+ t.string "rateable_type"
+ t.float "stars", :null => false
+ t.string "dimension"
+ t.datetime "created_at", :null => false
+ t.datetime "updated_at", :null => false
+ end
+
create_table "settings", :force => true do |t|
t.string "name", :default => "", :null => false
t.text "value"
@@ -593,20 +576,13 @@ ActiveRecord::Schema.define(:version => 20130918004629) do
create_table "shares", :force => true do |t|
t.date "created_on"
- t.string "title"
- t.string "share_type"
t.string "url"
- t.datetime "created_at", :null => false
- t.datetime "updated_at", :null => false
- t.integer "project_id"
- t.integer "user_id"
- t.string "description"
- end
-
- create_table "students", :force => true do |t|
- t.string "name"
+ t.string "title"
+ t.integer "share_type"
t.datetime "created_at", :null => false
t.datetime "updated_at", :null => false
+ t.integer "project_id"
+ t.integer "user_id"
end
create_table "students_for_courses", :force => true do |t|
@@ -667,7 +643,7 @@ ActiveRecord::Schema.define(:version => 20130918004629) do
create_table "tokens", :force => true do |t|
t.integer "user_id", :default => 0, :null => false
t.string "action", :limit => 30, :default => "", :null => false
- t.string "value", :limit => 40
+ t.string "value", :limit => 40, :default => "", :null => false
t.datetime "created_on", :null => false
end
@@ -693,7 +669,6 @@ ActiveRecord::Schema.define(:version => 20130918004629) do
t.integer "zip_code"
t.datetime "created_at", :null => false
t.datetime "updated_at", :null => false
- t.integer "identity"
t.string "technical_title"
end
@@ -717,14 +692,6 @@ ActiveRecord::Schema.define(:version => 20130918004629) do
add_index "user_statuses", ["changesets_count"], :name => "index_user_statuses_on_changesets_count"
add_index "user_statuses", ["watchers_count"], :name => "index_user_statuses_on_watchers_count"
- create_table "user_tags", :force => true do |t|
- t.integer "user_id"
- t.integer "tag_id"
- t.string "description"
- t.datetime "created_at", :null => false
- t.datetime "updated_at", :null => false
- end
-
create_table "users", :force => true do |t|
t.string "login", :default => "", :null => false
t.string "hashed_password", :limit => 40, :default => "", :null => false
diff --git a/public/stylesheets/application.css b/public/stylesheets/application.css
index cd2bc48f6..0326b6f3e 100644
--- a/public/stylesheets/application.css
+++ b/public/stylesheets/application.css
@@ -1182,6 +1182,12 @@ ul.properties li span {font-style:italic;}
.total-hours { font-size: 110%; font-weight: bold; }
.total-hours span.hours-int { font-size: 120%; }
.gender { width: 20%; }
+/*added by bai 澧炲姞浜嗘у埆銆佸湴鍖哄拰鍗曚綅鐨勬牱寮 */
+#my_account_form select.gender { width: 20%; }
+#my_account_form select.location {width: 31%;}
+#my_account_form .occupation { width: 56%; }
+/*end*/
+
.autoscroll {overflow-x: auto; padding:1px; margin-bottom: 1.2em;}
#user_login, #user_firstname, #user_lastname, #user_mail, #my_account_form select, #user_form select, #user_identity_url { width: 60%; }
@@ -1203,7 +1209,7 @@ p.pagination {margin-top:8px; font-size: 90%}
margin: 0;
padding: 3px 0 3px 0;
padding-left: 100px; /* width of left column containing the label elements *//*by young*/
- min-height: 1.8em;
+ /*/*min-height: 1.8em;*/ by bai*/
clear:left;
}
@@ -1292,9 +1298,10 @@ p.other-formats { text-align: right; font-size:0.9em; color: #666; }
a.atom { background: url(../images/feed.png) no-repeat 1px 50%; padding: 2px 0px 3px 16px; }
-em.info {font-style:normal;font-size:90%;color:#888;display:block;}
+/*modified by bai 鏀瑰彉浜嗗瓧浣撻鑹插拰鍔犵矖*/
+em.info {font-style:normal; font-size:90%; color:#505050; font-weight:bold; display:block;}
em.info.error {padding-left:20px; background:url(../images/exclamation.png) no-repeat 0 50%;}
-
+/*end*/
textarea.text_cf {width:90%;}
#tab-content-modules fieldset p {margin:3px 0 4px 0;}