diff --git a/app/controllers/projects_controller.rb b/app/controllers/projects_controller.rb
index b7427b1e9..af968144f 100644
--- a/app/controllers/projects_controller.rb
+++ b/app/controllers/projects_controller.rb
@@ -1,911 +1,911 @@
-# 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 ProjectsController < ApplicationController
- # if @project.project_type == 1
- layout 'base_projects'# by young
- menu_item :overview
- menu_item :roadmap, :only => :roadmap
- menu_item :settings, :only => :settings
-
- menu_item l(:label_sort_by_time), :only => :index
- menu_item l(:label_sort_by_active), :only => :index
- menu_item l(:label_sort_by_influence), :only => :index
-
- menu_item l(:label_homework), :only => :homework
- menu_item l(:label_course_file), :only => :index
- menu_item l(:label_course_news), :only => :index
- # end
-
-
- # layout 'base_courses'# by young
- # menu_item :overview
- # menu_item l(:label_homework), :only => :homework
- # menu_item :files, :only => :files
-#
- # layout 'base_courses'
- # menu_item l(:label_homework), :only => homework
- # menu_item l(:label_course_file), :only => files
- # menu_item l(:label_settings), :only => settings
-
- before_filter :find_project, :except => [ :index, :search,:list, :new, :create, :copy, :statistics, :new_join, :course, :enterprise_course, :course_enterprise]
- before_filter :authorize, :except => [:new_join, :new_homework, :homework, :statistics, :search, :watcherlist, :index, :list, :new, :create, :copy, :archive, :unarchive, :destroy, :member, :focus, :file,
- :statistics, :feedback, :course, :enterprise_course, :course_enterprise, :project_respond, :share]
- before_filter :authorize_global, :only => [:new, :create]
- before_filter :require_admin, :only => [ :copy, :archive, :unarchive, :destroy, :calendar]
- #by young
- # before_filter :member, :file, :statistics, :watcherlist
- # modified by fq
- before_filter :file, :statistics, :watcherlist
- #
- accept_rss_auth :index
- accept_api_auth :index, :show, :create, :update, :destroy
-
- after_filter :only => [:create, :edit, :update, :archive, :unarchive, :destroy] do |controller|
- if controller.request.post?
- controller.send :expire_action, :controller => 'welcome', :action => 'robots'
- end
- end
-
- helper :bids
- include BidsHelper
- helper :sort
- include SortHelper
- helper :custom_fields
- include CustomFieldsHelper
- helper :issues
- helper :queries
- include QueriesHelper
- helper :repositories
- include RepositoriesHelper
- include ProjectsHelper
- helper :members
- helper :activities
- helper :documents
- helper :watchers
- # helper :watcherlist
-
- ### added by william
- include ActsAsTaggableOn::TagsHelper
-
- # Lists visible projects
- # def index
- # respond_to do |format|
- # format.html {
- # scope = Project
- # unless params[:closed]
- # scope = scope.active
- # end
- # @projects = scope.visible.order('lft').all
- # }
- # format.api {
- # @offset, @limit = api_offset_and_limit
- # @project_count = Project.visible.count
- # @projects = Project.visible.offset(@offset).limit(@limit).order('lft').all
- # }
- # format.atom {
- # projects = Project.visible.order('created_on DESC').limit(Setting.feeds_limit.to_i).all
- # render_feed(projects, :title => "#{Setting.app_title}: #{l(:label_project_latest)}")
- # }
- # end
- # end
- def enterprise_course
- session[:enterprise_college] = 2
- respond_to do |format|
- format.html { redirect_to :back }
- #format.api { render_api_ok }
- end
- end
-
- def course_enterprise
- session[:enterprise_college] = 1
- respond_to do |format|
- format.html { redirect_to :back }
- #format.api { render_api_ok }
- end
- end
-
- def index
- #Modified by nie
- # @offset, @limit = api_offset_and_limit({:limit => 10})
- # @project_count = Project.visible.count
- # @project_pages = Paginator.new @project_count, @limit, params['page']
- # @offset ||= @project_pages.offset
- # @projects = Project.visible.offset(@offset).limit(@limit).order('lft').all
- @project_type = params[:project_type]
-
-
- @offset, @limit = api_offset_and_limit({:limit => 10})
- @projects_status = ProjectStatus.visible.where("project_type <> ? or project_type is null", 1)
- # @projects_status = ProjectStatus.visible
- # @projects_status.each do |project|
- # if Project.visible.find_by_id("#{project.project_id}")
- # project.project_type = Project.visible.find_by_id("#{project.project_id}").project_type
- # project.save
- # end
- # end
- # @projects.each do |project|
- # @admin = project.users_by_role[Role.find(3)]
- # unless @admin.nil?
- # @admin.each do |user|
- # ProjectInfo.create(:user_id => user.id, :project_id => project.id)
- # end
- #
- # end
- # end
- # @projects = Project.where("project_type <> ? or project_type is null", 1)
- # @projects.each do |project|
- # @id = project.id
- # @users = Member.find_by_sql("SELECT
- # members.user_id
- # FROM members
- # INNER JOIN users
- # ON members.user_id = users.id
- # WHERE members.project_id = #{@id}
- # AND (users.type = 'User' AND users.status = 1);")
- # @users.each do |user|
- # UserGrade.create(:project_id => project.id, :user_id => user.user_id)
- # end
- # #ProjectStatus.create(:changesets_count => project.changesets.count, :project_id => project.id, :watchers_count => project.watcher_users.count)
- # end
- # @projects_status = Project.visible.like(params[:name]) if params[:name].present?
- @project_count = @projects_status.count
- @project_pages = Paginator.new @project_count, @limit, params['page']
-
- @offset ||= @project_pages.reverse_offset
-
- # @projects = @projects.offset(@offset).limit(@limit).order('created_on DESC').all
- if params[:project_sort_type].present?
- case params[:project_sort_type]
- when '0'
- @offset ||= @project_pages.reverse_offset
- unless @offset == 0
- @projects_status = @projects_status.offset(@offset).limit(@limit).all.reverse
- else
- limit = @project_count % @limit
- if limit == 0
- limit = @limit
- end
- @projects_status = @projects_status.offset(@offset).limit(limit).all.reverse
- end
- @s_type = 0
- # @projects = @projects.sort {|x,y| y.created_on <=> x.created_on }
- # @projects = @projects[@offset, @limit]
- when '1'
- @offset ||= @project_pages.reverse_offset
- unless @offset == 0
- @projects_status = @projects_status.reorder('grade').offset(@offset).limit(@limit).all.reverse
- else
- limit = @project_count % @limit
- if limit == 0
- limit = @limit
- end
- @projects_status = @projects_status.reorder('grade').offset(@offset).limit(limit).all.reverse
- end
- @s_type = 1
-
- #@projects = @projects[@offset, @limit]
- when '2'
- @offset ||= @project_pages.reverse_offset
- unless @offset == 0
- @projects_status = @projects_status.reorder('watchers_count').offset(@offset).limit(@limit).all.reverse
- else
- limit = @project_count % @limit
- if limit == 0
- limit = @limit
- end
- @projects_status = @projects_status.reorder('watchers_count').offset(@offset).limit(limit).all.reverse
- end
- @s_type = 2
- end
- else
- @offset ||= @project_pages.reverse_offset
- unless @offset == 0
- @projects_status = @projects_status.reorder('grade').offset(@offset).limit(@limit).all.reverse
- else
- limit = @project_count % @limit
- if limit == 0
- limit = @limit
- end
- @projects_status = @projects_status.reorder('grade').offset(@offset).limit(limit).all.reverse
- end
- @s_type = 1
- # @projects = @projects.sort {|x,y| y.created_on <=> x.created_on }
- # @projects = @projects[@offset, @limit]
- end
-
- @projects = []
- @projects_status.each do |obj|
- @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|
- format.html {
- render :layout => 'base'
- scope = Project
- unless params[:closed]
- scope = scope.active
- end
- }
- format.api {
- # @offset, @limit = api_offset_and_limit
- # @project_count = Project.visible.count
- # @projects = Project.visible.offset(@offset).limit(@limit).order('lft').all
- }
- format.atom {
- projects = Project.visible.order('created_on DESC').limit(Setting.feeds_limit.to_i).all
- render_feed(projects, :title => "#{Setting.app_title}: #{l(:label_project_latest)}")
- }
- end
- end
-
- def course
- #Modified by nie
- # @offset, @limit = api_offset_and_limit({:limit => 10})
- # @project_count = Project.visible.count
- # @project_pages = Paginator.new @project_count, @limit, params['page']
- # @offset ||= @project_pages.offset
- # @projects = Project.visible.offset(@offset).limit(@limit).order('lft').all
- @project_type = params[:project_type]
-
- @offset, @limit = api_offset_and_limit({:limit => 10})
- @projects_status = ProjectStatus.visible.where("project_type = ?", 1)
- # @projects.each do |project|
- # @admin = project.users_by_role[Role.find(3)]
- # unless @admin.nil?
- # @admin.each do |user|
- # ProjectInfo.create(:user_id => user.id, :project_id => project.id)
- # end
- #
- # end
- # end
- # @projects.each do |project|
- # ProjectStatus.create(:changesets_count => project.changesets.count, :project_id => project.id, :watchers_count => project.watcher_users.count)
- # end
- #@projects_status = Project.visible.like(params[:name]) if params[:name].present?
- @project_count = @projects_status.count
- @project_pages = Paginator.new @project_count, @limit, params['page']
-
- @offset ||= @project_pages.reverse_offset
-
- #@projects = @projects.offset(@offset).limit(@limit).order('created_on DESC').all
- if params[:project_sort_type].present?
- case params[:project_sort_type]
- when '0'
- @offset ||= @project_pages.reverse_offset
- unless @offset == 0
- @projects_status = @projects_status.offset(@offset).limit(@limit).all.reverse
- else
- limit = @project_count % @limit
- if limit == 0
- limit = @limit
- end
- @projects_status = @projects_status.offset(@offset).limit(limit).all.reverse
- end
- @s_type = 0
- # @projects = @projects.sort {|x,y| y.created_on <=> x.created_on }
- # @projects = @projects[@offset, @limit]
- when '1'
- @offset ||= @project_pages.reverse_offset
- unless @offset == 0
- @projects_status = @projects_status.reorder('changesets_count').offset(@offset).limit(@limit).all.reverse
- else
- limit = @project_count % @limit
- if limit == 0
- limit = @limit
- end
- @projects_status = @projects_status.reorder('changesets_count').offset(@offset).limit(limit).all.reverse
- end
- @s_type = 1
-
- #@projects = @projects[@offset, @limit]
- when '2'
- @offset ||= @project_pages.reverse_offset
- unless @offset == 0
- @projects_status = @projects_status.reorder('watchers_count').offset(@offset).limit(@limit).all.reverse
- else
- limit = @project_count % @limit
- if limit == 0
- limit = @limit
- end
- @projects_status = @projects_status.reorder('watchers_count').offset(@offset).limit(limit).all.reverse
- end
- @s_type = 2
- end
- else
- @offset ||= @project_pages.reverse_offset
- unless @offset == 0
- @projects_status = @projects_status.reorder('changesets_count').offset(@offset).limit(@limit).all.reverse
- else
- limit = @project_count % @limit
- if limit == 0
- limit = @limit
- end
- @projects_status = @projects_status.reorder('changesets_count').offset(@offset).limit(limit).all.reverse
- end
- @s_type = 1
- # @projects = @projects.sort {|x,y| y.created_on <=> x.created_on }
- # @projects = @projects[@offset, @limit]
- end
-
- @projects = []
- @projects_status.each do |obj|
- @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|
- format.html {
- render :layout => 'base'
- scope = Project
- unless params[:closed]
- scope = scope.active
- end
- }
- format.api {
- # @offset, @limit = api_offset_and_limit
- # @project_count = Project.visible.count
- # @projects = Project.visible.offset(@offset).limit(@limit).order('lft').all
- }
- format.atom {
- projects = Project.visible.order('created_on DESC').limit(Setting.feeds_limit.to_i).all
- render_feed(projects, :title => "#{Setting.app_title}: #{l(:label_project_latest)}")
- }
- end
- end
-
- def search
- #modified by nie
- @projects = Project.visible
- @projects = @projects.visible.where('project_type = ?', params[:project_type]).like(params[:name]) if params[:name].present?
- @offset, @limit = api_offset_and_limit({:limit => 10})
- @project_count = @projects.visible.count
- @project_pages = Paginator.new @project_count, @limit, params['page']
- @offset ||= @project_pages.offset
- @projects = @projects.visible.offset(@offset).limit(@limit).all
- respond_to do |format|
- format.html {
- render :layout => 'base'
- scope = Project
- unless params[:closed]
- scope = scope.active
- end
- }
- format.api {
- # @offset, @limit = api_offset_and_limit
- # @project_count = Project.visible.count
- # @projects = Project.visible.offset(@offset).limit(@limit).order('lft').all
- }
- format.atom {
- projects = Project.visible.order('created_on DESC').limit(Setting.feeds_limit.to_i).all
- render_feed(projects, :title => "#{Setting.app_title}: #{l(:label_project_latest)}")
- }
- end
- end
-
- # added by fq
- def new_join
- @course = Project.find(params[:object_id])
- end
-
- #Added by young
- def homework
- @offset, @limit = api_offset_and_limit({:limit => 10})
- @bids = @project.homeworks
- @bids = @bids.like(params[:name]) if params[:name].present?
- @bid_count = @bids.count
- @bid_pages = Paginator.new @bid_count, @limit, params['page']
-
- @offset ||= @bid_pages.reverse_offset
- #@bids = @bids.offset(@offset).limit(@limit).all.reverse
- unless @offset == 0
- @bids = @bids.offset(@offset).limit(@limit).all.reverse
- else
- limit = @bid_count % @limit
- @bids = @bids.offset(@offset).limit(limit).all.reverse
- end
- render :layout => 'base_courses'
-
- end
-
- def new_homework
- if User.current.logged? && (User.current.admin? || (!Member.where('user_id = ? and project_id = ?', User.current.id, @project.id).first.nil? && (Member.where('user_id = ? and project_id = ?', User.current.id, @project.id).first.roles&Role.where('id = ? or id = ?', 3, 7)).size >0))
- @homework = Bid.new
- @homework.safe_attributes = params[:bid]
- render :layout => 'base_courses'
- else
- render_404
- end
-
- end
- #Ended by young
-
- def feedback
- @jours = @project.journals_for_messages.reverse
- @limit = 10
- @feedback_count = @jours.count
- @feedback_pages = Paginator.new @feedback_count, @limit, params['page']
- @offset ||= @feedback_pages.offset
- @jour = @jours[@offset, @limit]
- @state = false
- end
-
- def project_respond
-
- if params[:project_respond].size>0
- jour = JournalsForMessage.find(params[:reference_id]) if params[:reference_id]
- if jour
- user = jour.user
- text = jour.notes
- else
- user = User.current
- text = []
- end
- # Replaces pre blocks with [...]
- text = text.to_s.strip.gsub(%r{
((.|\s)*?)
}m, '[...]')
- reference_content = "> #{ll(Setting.default_language, :text_user_wrote, user)}\n> "
- reference_content << text.gsub(/(\r?\n|\r\n?)/, "\n> ") + "\n\n"
- # reference_message = JournalForMessage.find(params[:reference_id])
- message = params[:project_respond] + "\n" + reference_content
-
-
- user.add_jour(User.current, message, user.id)
- flash[:notice]=l(:label_projects_feedback_respond_success)
- # if a_message.size > 5
- # @message = a_message[-5, 5]
- # else
- # @message = a_message
- # end
- # @message_count = a_message.count
- end
-
- respond_to do |format|
- format.html { redirect_to :back }
- #format.api { render_api_ok }
- end
- # redirect_to project_feedback_path(@project)
- end
-
- def new
- @project_type = params[:project_type]
- @course_tag = params[:course]
- @issue_custom_fields = IssueCustomField.sorted.all
- @trackers = Tracker.sorted.all
- @project = Project.new
- @project.safe_attributes = params[:project]
- ##add by huang
- @course=Course.new
- @course.safe_attributes = params[:course]
- ##end
- render :layout => 'base'
- end
-
- def share
- @shares = @project.shares.reverse
- @base_courses_tag = @project.project_type
- respond_to do |format|
- format.html{render :layout => 'base_courses' if @base_courses_tag==1}
- format.api
- end
- end
-
- def create
-
- @course_tag = params[:project][:project_type]
- if(@course_tag=="1")
- if User.current.user_extensions.identity == 0
- @course = Course.new
- @course.extra='course' + DateTime.parse(Time.now.to_s).strftime('%Y-%m-%d_%H-%M-%S').to_s
- @course.safe_attributes = params[:project][:course]
- @course.tea_id = User.current.id
- # added by bai
- @course.term = params[:term]
- @course.time = params[:time]
- end
- # end
- # @course.save
- # project = ProjectInfo.create(:user_id => User.current.id, :project_id => @project.id)
- # project_status = ProjectStatus.create(:project_id => @project.id)
- end
- @issue_custom_fields = IssueCustomField.sorted.all
- @trackers = Tracker.sorted.all
- @project = Project.new
- @project.safe_attributes = params[:project]
- if @course_tag == '1'
- @project.identifier = @course.extra
- end
- if @course_tag == '1'
- if User.current.user_extensions.identity == 0
- if@course.save
- if validate_parent_id && @project.save
- @project.set_allowed_parent!(params[:project]['parent_id']) if params[:project].has_key?('parent_id')
- # Add current user as a project member if he is not admin
- unless User.current.admin?
- 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)
- UserGrade.create(:user_id => User.current.id, :project_id => @project.id, :grade => 0)
- if params[:project][:is_public] == '1'
- project_status = ProjectStatus.create(:project_id => @project.id, :watchers_count => 0, :changesets_count => 0, :grade => 0, :project_type => @course_tag)
- end
- @project.members << m
- @project.project_infos << project
- end
- respond_to do |format|
- format.html {
- flash[:notice] = l(:notice_successful_create)
- if params[:continue]
- attrs = {:parent_id => @project.parent_id}.reject {|k,v| v.nil?}
- redirect_to new_project_path(attrs, :course => '0')
- #Added by young
-
- elsif params[:course_continue]
- redirect_to new_project_path(:course => '1')
- #Ended by young
- else
- redirect_to settings_project_path(@project,:project_type => 1)
- end
- }
- format.api { render :action => 'show', :status => :created, :location => url_for(:controller => 'projects', :action => 'show', :id => @project.id) }
- end
- else
- @course.destroy
- respond_to do |format|
- format.html { render :action => 'new', :layout => 'base'}#Added by young
- format.api { render_validation_errors(@project) }
- end
- end
- else
- if validate_parent_id && @project.save
- @project.delete
- respond_to do |format|
- format.html { render :action => 'new', :layout => 'base'}#Added by young
- format.api { render_validation_errors(@project) }
- end
- else
- respond_to do |format|
- format.html { render :action => 'new', :layout => 'base'}#Added by young
- format.api { render_validation_errors(@project) }
- end
- end
- end
- end
- else
- if validate_parent_id && @project.save
- @project.set_allowed_parent!(params[:project]['parent_id']) if params[:project].has_key?('parent_id')
- # Add current user as a project member if he is not admin
- unless User.current.admin?
- 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)
- if params[:project][:is_public] == '1' || @course_tag=="1"
- project_status = ProjectStatus.create(:project_id => @project.id, :watchers_count => 0, :changesets_count => 0)
- end
- @project.members << m
- @project.project_infos << project
- end
- respond_to do |format|
- format.html {
- flash[:notice] = l(:notice_successful_create)
- if params[:continue]
- attrs = {:parent_id => @project.parent_id}.reject {|k,v| v.nil?}
- redirect_to new_project_path(attrs, :course => '0')
- #Added by young
-
- elsif params[:course_continue]
- redirect_to new_project_path(:course => '1')
- #Ended by young
- else
- redirect_to settings_project_path(@project)
- end
- }
- format.api { render :action => 'show', :status => :created, :location => url_for(:controller => 'projects', :action => 'show', :id => @project.id) }
- end
- else
- respond_to do |format|
- format.html { render :action => 'new', :layout => 'base'}#Added by young
- format.api { render_validation_errors(@project) }
- end
- end
- end
- end
-
- def copy
- @issue_custom_fields = IssueCustomField.sorted.all
- @trackers = Tracker.sorted.all
- @source_project = Project.find(params[:id])
- if request.get?
- @project = Project.copy_from(@source_project)
- @project.identifier = Project.next_identifier if Setting.sequential_project_identifiers?
- else
- Mailer.with_deliveries(params[:notifications] == '1') do
- @project = Project.new
- @project.safe_attributes = params[:project]
- if validate_parent_id && @project.copy(@source_project, :only => params[:only])
- @project.set_allowed_parent!(params[:project]['parent_id']) if params[:project].has_key?('parent_id')
- flash[:notice] = l(:notice_successful_create)
- redirect_to settings_project_path(@project)
- elsif !@project.new_record?
- # Project was created
- # But some objects were not copied due to validation failures
- # (eg. issues from disabled trackers)
- # TODO: inform about that
- redirect_to settings_project_path(@project)
- end
- end
- end
- rescue ActiveRecord::RecordNotFound
- # source_project not found
- render_404
- end
-
- # Show @project
- def show
-
- @project_type = params[:project_type]
-
- # try to redirect to the requested menu item
- if params[:jump] && redirect_to_project_menu_item(@project, params[:jump])
- return
- end
-
- @users_by_role = @project.users_by_role
- @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
- if(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)
- end
- cond = @project.project_condition(Setting.display_subprojects_issues?)
- @open_issues_by_tracker = Issue.visible.open.where(cond).count(:group => :tracker)
- @total_issues_by_tracker = Issue.visible.where(cond).count(:group => :tracker)
-
- if User.current.allowed_to?(:view_time_entries, @project)
- @total_hours = TimeEntry.visible.sum(:hours, :include => :project, :conditions => cond).to_f
- end
-
- @key = User.current.rss_key
- #新增内容
- @days = Setting.activity_days_default.to_i
-
- if params[:from]
- begin; @date_to = params[:from].to_date + 1; rescue; end
- end
-
- has = {
- "show_issues" => true,
- "show_files" => true,
- "show_documents" => true,
- "show_messages" => true,
- "show_news" => true,
- "show_bids" => true
- }
- @date_to ||= Date.today + 1
- @date_from = @date_to - @days
- @with_subprojects = params[:with_subprojects].nil? ? Setting.display_subprojects_issues? : (params[:with_subprojects] == '1')
- @author = (params[:user_id].blank? ? nil : User.active.find(params[:user_id]))
- # 决定显示所用用户或单个用户活动
- @activity = Redmine::Activity::Fetcher.new(User.current, :project => @project,
- :with_subprojects => @with_subprojects,
- :author => @author)
- @activity.scope_select {|t| !has["show_#{t}"].nil?}
- # @activity.scope = (@author.nil? ? :default : :all) if @activity.scope.empty?
- #Added by young
- events = @activity.events(@date_from, @date_to)
-
- @offset, @limit = api_offset_and_limit({:limit => 10})
- @events_count = events.count
- @events_pages = Paginator.new @events_count, @limit, params['page']
- @offset ||= @events_pages.offset
- events = events.slice(@offset,@limit)
- #Ended by young
- @events_by_day = events.group_by {|event| User.current.time_to_date(event.event_datetime)}
- # documents
- @sort_by = %w(category date title author).include?(params[:sort_by]) ? params[:sort_by] : 'category'
- documents = @project.documents.includes(:attachments, :category).all
- case @sort_by
- when 'date'
- @grouped = documents.group_by {|d| d.updated_on.to_date }
- when 'title'
- @grouped = documents.group_by {|d| d.title.first.upcase}
- when 'author'
- @grouped = documents.select{|d| d.attachments.any?}.group_by {|d| d.attachments.last.author}
- else
- @grouped = documents.group_by(&:category)
- end
- @document = @project.documents.build
- #
- @base_courses_tag = @project.project_type
- respond_to do |format|
- format.html{render :layout => 'base_courses' if @base_courses_tag==1}
- format.api
- end
- end
-
- def settings
- @issue_custom_fields = IssueCustomField.sorted.all
- @issue_category ||= IssueCategory.new
- @member ||= @project.members.new
- @trackers = Tracker.sorted.all
- @wiki ||= @project.wiki
- #Added by young
- # @course_tag = params[:course]
- # if @course_tag == '1'
- if @project.project_type == 1
- @course = Course.find_by_extra(@project.identifier)
- render :layout => 'base_courses'
- else
- render :layout => 'base_projects'
- end
- #Ended by young
- end
-
- def edit
- end
-
- #by young
- def member
- if @project.project_type == 1
- render :layout => 'base_courses'
- end
- # roles = Role.find_all_givable
- # members = @project.member_principals.includes(:roles, :principal).all.sort
-#
- # users = UserGrade.find_by_sql("select * from user_grades where project_id = #{@project.id}").sort {|a,b| a[:grade] <=> b[:grade]}
-#
- # temp = []
- # users.each do |user|
- # members.each do |member|
- # if member[:user_id] == user[:user_id]
- # temp << member
- # end
- # end
- # end
- # temps = temp.reverse
- end
-
- # def news
- # if @project.project_type == 1
- # render :layout => 'base_courses'
- # end
- # end
-
- def file
- # if @project.project_type == 1
- # render :layout => 'base_courses'
- # end
- # @course_tag = params[:course]
- # if @course_tag == '1'
- # render :layout => 'base_courses'
- # end
-
- # User.current
- end
-
- def statistics
-
- end
- #end
-
- def update
- @project.safe_attributes = params[:project]
- if validate_parent_id && @project.save
- @course = Course.find_by_extra(@project.identifier)
- unless @course.nil?
- @course.password = params[:project][:course][:password]
- # added by bai
- @course.term = params[:term]
- @course.time = params[:time]
- # end
- @course.save
- end
- @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,:grade => 0, :project_type => 1)
- end
-
- respond_to do |format|
- format.html {
- flash[:notice] = l(:notice_successful_update)
- redirect_to settings_project_path(@project,:course => @project.project_type)
- }
- format.api { render_api_ok }
- end
- else
- respond_to do |format|
- format.html {
- settings
- render :action => 'settings'
- }
- format.api { render_validation_errors(@project) }
- end
- end
- end
-
- def modules
- @project.enabled_module_names = params[:enabled_module_names]
- flash[:notice] = l(:notice_successful_update)
- redirect_to settings_project_path(@project, :tab => 'modules')
- end
-
- def archive
- if request.post?
- unless @project.archive
- flash[:error] = l(:error_can_not_archive_project)
- end
- end
- redirect_to admin_projects_path(:status => params[:status])
- end
-
- def unarchive
- @project.unarchive if request.post? && !@project.active?
- redirect_to admin_projects_path(:status => params[:status])
- end
-
- def close
- @project.close
- redirect_to project_path(@project)
- end
-
- def reopen
- @project.reopen
- redirect_to project_path(@project)
- end
-
- # Delete @project
- def destroy
- @project_to_destroy = @project
- if api_request? || params[:confirm]
- @project_to_destroy.destroy
- respond_to do |format|
- format.html { redirect_to admin_projects_path }
- format.api { render_api_ok }
- end
- else
- render :layout => "base"
- end
- # hide project in layout
- @project = nil
- end
-
- private
-
- # Validates parent_id param according to user's permissions
- # TODO: move it to Project model in a validation that depends on User.current
- def validate_parent_id
- return true if User.current.admin?
- parent_id = params[:project] && params[:project][:parent_id]
- if parent_id || @project.new_record?
- parent = parent_id.blank? ? nil : Project.find_by_id(parent_id.to_i)
- unless @project.allowed_parents.include?(parent)
- @project.errors.add :parent_id, :invalid
- return false
- end
- end
- true
- end
-
- # added by huang
-
- def watcherlist
- if @watched
- @users -= watched.watcher_users
- 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 ProjectsController < ApplicationController
+ # if @project.project_type == 1
+ layout 'base_projects'# by young
+ menu_item :overview
+ menu_item :roadmap, :only => :roadmap
+ menu_item :settings, :only => :settings
+
+ menu_item l(:label_sort_by_time), :only => :index
+ menu_item l(:label_sort_by_active), :only => :index
+ menu_item l(:label_sort_by_influence), :only => :index
+
+ menu_item l(:label_homework), :only => :homework
+ menu_item l(:label_course_file), :only => :index
+ menu_item l(:label_course_news), :only => :index
+ # end
+
+
+ # layout 'base_courses'# by young
+ # menu_item :overview
+ # menu_item l(:label_homework), :only => :homework
+ # menu_item :files, :only => :files
+#
+ # layout 'base_courses'
+ # menu_item l(:label_homework), :only => homework
+ # menu_item l(:label_course_file), :only => files
+ # menu_item l(:label_settings), :only => settings
+
+ before_filter :find_project, :except => [ :index, :search,:list, :new, :create, :copy, :statistics, :new_join, :course, :enterprise_course, :course_enterprise]
+ before_filter :authorize, :except => [:new_join, :new_homework, :homework, :statistics, :search, :watcherlist, :index, :list, :new, :create, :copy, :archive, :unarchive, :destroy, :member, :focus, :file,
+ :statistics, :feedback, :course, :enterprise_course, :course_enterprise, :project_respond, :share]
+ before_filter :authorize_global, :only => [:new, :create]
+ before_filter :require_admin, :only => [ :copy, :archive, :unarchive, :destroy, :calendar]
+ #by young
+ # before_filter :member, :file, :statistics, :watcherlist
+ # modified by fq
+ before_filter :file, :statistics, :watcherlist
+ #
+ accept_rss_auth :index
+ accept_api_auth :index, :show, :create, :update, :destroy
+
+ after_filter :only => [:create, :edit, :update, :archive, :unarchive, :destroy] do |controller|
+ if controller.request.post?
+ controller.send :expire_action, :controller => 'welcome', :action => 'robots'
+ end
+ end
+
+ helper :bids
+ include BidsHelper
+ helper :sort
+ include SortHelper
+ helper :custom_fields
+ include CustomFieldsHelper
+ helper :issues
+ helper :queries
+ include QueriesHelper
+ helper :repositories
+ include RepositoriesHelper
+ include ProjectsHelper
+ helper :members
+ helper :activities
+ helper :documents
+ helper :watchers
+ # helper :watcherlist
+
+ ### added by william
+ include ActsAsTaggableOn::TagsHelper
+
+ # Lists visible projects
+ # def index
+ # respond_to do |format|
+ # format.html {
+ # scope = Project
+ # unless params[:closed]
+ # scope = scope.active
+ # end
+ # @projects = scope.visible.order('lft').all
+ # }
+ # format.api {
+ # @offset, @limit = api_offset_and_limit
+ # @project_count = Project.visible.count
+ # @projects = Project.visible.offset(@offset).limit(@limit).order('lft').all
+ # }
+ # format.atom {
+ # projects = Project.visible.order('created_on DESC').limit(Setting.feeds_limit.to_i).all
+ # render_feed(projects, :title => "#{Setting.app_title}: #{l(:label_project_latest)}")
+ # }
+ # end
+ # end
+ def enterprise_course
+ session[:enterprise_college] = 2
+ respond_to do |format|
+ format.html { redirect_to :back }
+ #format.api { render_api_ok }
+ end
+ end
+
+ def course_enterprise
+ session[:enterprise_college] = 1
+ respond_to do |format|
+ format.html { redirect_to :back }
+ #format.api { render_api_ok }
+ end
+ end
+
+ def index
+ #Modified by nie
+ # @offset, @limit = api_offset_and_limit({:limit => 10})
+ # @project_count = Project.visible.count
+ # @project_pages = Paginator.new @project_count, @limit, params['page']
+ # @offset ||= @project_pages.offset
+ # @projects = Project.visible.offset(@offset).limit(@limit).order('lft').all
+ @project_type = params[:project_type]
+
+
+ @offset, @limit = api_offset_and_limit({:limit => 10})
+ @projects_status = ProjectStatus.visible.where("project_type <> ? or project_type is null", 1)
+ # @projects_status = ProjectStatus.visible
+ # @projects_status.each do |project|
+ # if Project.visible.find_by_id("#{project.project_id}")
+ # project.project_type = Project.visible.find_by_id("#{project.project_id}").project_type
+ # project.save
+ # end
+ # end
+ # @projects.each do |project|
+ # @admin = project.users_by_role[Role.find(3)]
+ # unless @admin.nil?
+ # @admin.each do |user|
+ # ProjectInfo.create(:user_id => user.id, :project_id => project.id)
+ # end
+ #
+ # end
+ # end
+ # @projects = Project.where("project_type <> ? or project_type is null", 1)
+ # @projects.each do |project|
+ # @id = project.id
+ # @users = Member.find_by_sql("SELECT
+ # members.user_id
+ # FROM members
+ # INNER JOIN users
+ # ON members.user_id = users.id
+ # WHERE members.project_id = #{@id}
+ # AND (users.type = 'User' AND users.status = 1);")
+ # @users.each do |user|
+ # UserGrade.create(:project_id => project.id, :user_id => user.user_id)
+ # end
+ # #ProjectStatus.create(:changesets_count => project.changesets.count, :project_id => project.id, :watchers_count => project.watcher_users.count)
+ # end
+ # @projects_status = Project.visible.like(params[:name]) if params[:name].present?
+ @project_count = @projects_status.count
+ @project_pages = Paginator.new @project_count, @limit, params['page']
+
+ @offset ||= @project_pages.reverse_offset
+
+ # @projects = @projects.offset(@offset).limit(@limit).order('created_on DESC').all
+ if params[:project_sort_type].present?
+ case params[:project_sort_type]
+ when '0'
+ @offset ||= @project_pages.reverse_offset
+ unless @offset == 0
+ @projects_status = @projects_status.offset(@offset).limit(@limit).all.reverse
+ else
+ limit = @project_count % @limit
+ if limit == 0
+ limit = @limit
+ end
+ @projects_status = @projects_status.offset(@offset).limit(limit).all.reverse
+ end
+ @s_type = 0
+ # @projects = @projects.sort {|x,y| y.created_on <=> x.created_on }
+ # @projects = @projects[@offset, @limit]
+ when '1'
+ @offset ||= @project_pages.reverse_offset
+ unless @offset == 0
+ @projects_status = @projects_status.reorder('grade').offset(@offset).limit(@limit).all.reverse
+ else
+ limit = @project_count % @limit
+ if limit == 0
+ limit = @limit
+ end
+ @projects_status = @projects_status.reorder('grade').offset(@offset).limit(limit).all.reverse
+ end
+ @s_type = 1
+
+ #@projects = @projects[@offset, @limit]
+ when '2'
+ @offset ||= @project_pages.reverse_offset
+ unless @offset == 0
+ @projects_status = @projects_status.reorder('watchers_count').offset(@offset).limit(@limit).all.reverse
+ else
+ limit = @project_count % @limit
+ if limit == 0
+ limit = @limit
+ end
+ @projects_status = @projects_status.reorder('watchers_count').offset(@offset).limit(limit).all.reverse
+ end
+ @s_type = 2
+ end
+ else
+ @offset ||= @project_pages.reverse_offset
+ unless @offset == 0
+ @projects_status = @projects_status.reorder('grade').offset(@offset).limit(@limit).all.reverse
+ else
+ limit = @project_count % @limit
+ if limit == 0
+ limit = @limit
+ end
+ @projects_status = @projects_status.reorder('grade').offset(@offset).limit(limit).all.reverse
+ end
+ @s_type = 1
+ # @projects = @projects.sort {|x,y| y.created_on <=> x.created_on }
+ # @projects = @projects[@offset, @limit]
+ end
+
+ @projects = []
+ @projects_status.each do |obj|
+ @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|
+ format.html {
+ render :layout => 'base'
+ scope = Project
+ unless params[:closed]
+ scope = scope.active
+ end
+ }
+ format.api {
+ # @offset, @limit = api_offset_and_limit
+ # @project_count = Project.visible.count
+ # @projects = Project.visible.offset(@offset).limit(@limit).order('lft').all
+ }
+ format.atom {
+ projects = Project.visible.order('created_on DESC').limit(Setting.feeds_limit.to_i).all
+ render_feed(projects, :title => "#{Setting.app_title}: #{l(:label_project_latest)}")
+ }
+ end
+ end
+
+ def course
+ #Modified by nie
+ # @offset, @limit = api_offset_and_limit({:limit => 10})
+ # @project_count = Project.visible.count
+ # @project_pages = Paginator.new @project_count, @limit, params['page']
+ # @offset ||= @project_pages.offset
+ # @projects = Project.visible.offset(@offset).limit(@limit).order('lft').all
+ @project_type = params[:project_type]
+
+ @offset, @limit = api_offset_and_limit({:limit => 10})
+ @projects_status = ProjectStatus.visible.where("project_type = ?", 1)
+ # @projects.each do |project|
+ # @admin = project.users_by_role[Role.find(3)]
+ # unless @admin.nil?
+ # @admin.each do |user|
+ # ProjectInfo.create(:user_id => user.id, :project_id => project.id)
+ # end
+ #
+ # end
+ # end
+ # @projects.each do |project|
+ # ProjectStatus.create(:changesets_count => project.changesets.count, :project_id => project.id, :watchers_count => project.watcher_users.count)
+ # end
+ #@projects_status = Project.visible.like(params[:name]) if params[:name].present?
+ @project_count = @projects_status.count
+ @project_pages = Paginator.new @project_count, @limit, params['page']
+
+ @offset ||= @project_pages.reverse_offset
+
+ #@projects = @projects.offset(@offset).limit(@limit).order('created_on DESC').all
+ if params[:project_sort_type].present?
+ case params[:project_sort_type]
+ when '0'
+ @offset ||= @project_pages.reverse_offset
+ unless @offset == 0
+ @projects_status = @projects_status.offset(@offset).limit(@limit).all.reverse
+ else
+ limit = @project_count % @limit
+ if limit == 0
+ limit = @limit
+ end
+ @projects_status = @projects_status.offset(@offset).limit(limit).all.reverse
+ end
+ @s_type = 0
+ # @projects = @projects.sort {|x,y| y.created_on <=> x.created_on }
+ # @projects = @projects[@offset, @limit]
+ when '1'
+ @offset ||= @project_pages.reverse_offset
+ unless @offset == 0
+ @projects_status = @projects_status.reorder('changesets_count').offset(@offset).limit(@limit).all.reverse
+ else
+ limit = @project_count % @limit
+ if limit == 0
+ limit = @limit
+ end
+ @projects_status = @projects_status.reorder('changesets_count').offset(@offset).limit(limit).all.reverse
+ end
+ @s_type = 1
+
+ #@projects = @projects[@offset, @limit]
+ when '2'
+ @offset ||= @project_pages.reverse_offset
+ unless @offset == 0
+ @projects_status = @projects_status.reorder('watchers_count').offset(@offset).limit(@limit).all.reverse
+ else
+ limit = @project_count % @limit
+ if limit == 0
+ limit = @limit
+ end
+ @projects_status = @projects_status.reorder('watchers_count').offset(@offset).limit(limit).all.reverse
+ end
+ @s_type = 2
+ end
+ else
+ @offset ||= @project_pages.reverse_offset
+ unless @offset == 0
+ @projects_status = @projects_status.reorder('changesets_count').offset(@offset).limit(@limit).all.reverse
+ else
+ limit = @project_count % @limit
+ if limit == 0
+ limit = @limit
+ end
+ @projects_status = @projects_status.reorder('changesets_count').offset(@offset).limit(limit).all.reverse
+ end
+ @s_type = 1
+ # @projects = @projects.sort {|x,y| y.created_on <=> x.created_on }
+ # @projects = @projects[@offset, @limit]
+ end
+
+ @projects = []
+ @projects_status.each do |obj|
+ @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|
+ format.html {
+ render :layout => 'base'
+ scope = Project
+ unless params[:closed]
+ scope = scope.active
+ end
+ }
+ format.api {
+ # @offset, @limit = api_offset_and_limit
+ # @project_count = Project.visible.count
+ # @projects = Project.visible.offset(@offset).limit(@limit).order('lft').all
+ }
+ format.atom {
+ projects = Project.visible.order('created_on DESC').limit(Setting.feeds_limit.to_i).all
+ render_feed(projects, :title => "#{Setting.app_title}: #{l(:label_project_latest)}")
+ }
+ end
+ end
+
+ def search
+ #modified by nie
+ @projects = Project.visible
+ @projects = @projects.visible.where('project_type = ?', params[:project_type]).like(params[:name]) if params[:name].present?
+ @offset, @limit = api_offset_and_limit({:limit => 10})
+ @project_count = @projects.visible.count
+ @project_pages = Paginator.new @project_count, @limit, params['page']
+ @offset ||= @project_pages.offset
+ @projects = @projects.visible.offset(@offset).limit(@limit).all
+ respond_to do |format|
+ format.html {
+ render :layout => 'base'
+ scope = Project
+ unless params[:closed]
+ scope = scope.active
+ end
+ }
+ format.api {
+ # @offset, @limit = api_offset_and_limit
+ # @project_count = Project.visible.count
+ # @projects = Project.visible.offset(@offset).limit(@limit).order('lft').all
+ }
+ format.atom {
+ projects = Project.visible.order('created_on DESC').limit(Setting.feeds_limit.to_i).all
+ render_feed(projects, :title => "#{Setting.app_title}: #{l(:label_project_latest)}")
+ }
+ end
+ end
+
+ # added by fq
+ def new_join
+ @course = Project.find(params[:object_id])
+ end
+
+ #Added by young
+ def homework
+ @offset, @limit = api_offset_and_limit({:limit => 10})
+ @bids = @project.homeworks
+ @bids = @bids.like(params[:name]) if params[:name].present?
+ @bid_count = @bids.count
+ @bid_pages = Paginator.new @bid_count, @limit, params['page']
+
+ @offset ||= @bid_pages.reverse_offset
+ #@bids = @bids.offset(@offset).limit(@limit).all.reverse
+ unless @offset == 0
+ @bids = @bids.offset(@offset).limit(@limit).all.reverse
+ else
+ limit = @bid_count % @limit
+ @bids = @bids.offset(@offset).limit(limit).all.reverse
+ end
+ render :layout => 'base_courses'
+
+ end
+
+ def new_homework
+ if User.current.logged? && (User.current.admin? || (!Member.where('user_id = ? and project_id = ?', User.current.id, @project.id).first.nil? && (Member.where('user_id = ? and project_id = ?', User.current.id, @project.id).first.roles&Role.where('id = ? or id = ?', 3, 7)).size >0))
+ @homework = Bid.new
+ @homework.safe_attributes = params[:bid]
+ render :layout => 'base_courses'
+ else
+ render_404
+ end
+
+ end
+ #Ended by young
+
+ def feedback
+ @jours = @project.journals_for_messages.reverse
+ @limit = 10
+ @feedback_count = @jours.count
+ @feedback_pages = Paginator.new @feedback_count, @limit, params['page']
+ @offset ||= @feedback_pages.offset
+ @jour = @jours[@offset, @limit]
+ @state = false
+ end
+
+ def project_respond
+
+ if params[:project_respond].size>0
+ jour = JournalsForMessage.find(params[:reference_id]) if params[:reference_id]
+ if jour
+ user = jour.user
+ text = jour.notes
+ else
+ user = User.current
+ text = []
+ end
+ # Replaces pre blocks with [...]
+ text = text.to_s.strip.gsub(%r{((.|\s)*?)
}m, '[...]')
+ reference_content = "> #{ll(Setting.default_language, :text_user_wrote, user)}\n> "
+ reference_content << text.gsub(/(\r?\n|\r\n?)/, "\n> ") + "\n\n"
+ # reference_message = JournalForMessage.find(params[:reference_id])
+ message = params[:project_respond] + "\n" + reference_content
+
+
+ user.add_jour(User.current, message, user.id)
+ flash[:notice]=l(:label_projects_feedback_respond_success)
+ # if a_message.size > 5
+ # @message = a_message[-5, 5]
+ # else
+ # @message = a_message
+ # end
+ # @message_count = a_message.count
+ end
+
+ respond_to do |format|
+ format.html { redirect_to :back }
+ #format.api { render_api_ok }
+ end
+ # redirect_to project_feedback_path(@project)
+ end
+
+ def new
+ @project_type = params[:project_type]
+ @course_tag = params[:course]
+ @issue_custom_fields = IssueCustomField.sorted.all
+ @trackers = Tracker.sorted.all
+ @project = Project.new
+ @project.safe_attributes = params[:project]
+ ##add by huang
+ @course=Course.new
+ @course.safe_attributes = params[:course]
+ ##end
+ render :layout => 'base'
+ end
+
+ def share
+ @shares = @project.shares.reverse
+ @base_courses_tag = @project.project_type
+ respond_to do |format|
+ format.html{render :layout => 'base_courses' if @base_courses_tag==1}
+ format.api
+ end
+ end
+
+ def create
+
+ @course_tag = params[:project][:project_type]
+ if(@course_tag=="1")
+ if User.current.user_extensions.identity == 0
+ @course = Course.new
+ @course.extra='course' + DateTime.parse(Time.now.to_s).strftime('%Y-%m-%d_%H-%M-%S').to_s
+ @course.safe_attributes = params[:project][:course]
+ @course.tea_id = User.current.id
+ # added by bai
+ @course.term = params[:term]
+ @course.time = params[:time]
+ end
+ # end
+ # @course.save
+ # project = ProjectInfo.create(:user_id => User.current.id, :project_id => @project.id)
+ # project_status = ProjectStatus.create(:project_id => @project.id)
+ end
+ @issue_custom_fields = IssueCustomField.sorted.all
+ @trackers = Tracker.sorted.all
+ @project = Project.new
+ @project.safe_attributes = params[:project]
+ if @course_tag == '1'
+ @project.identifier = @course.extra
+ end
+ if @course_tag == '1'
+ if User.current.user_extensions.identity == 0
+ if@course.save
+ if validate_parent_id && @project.save
+ @project.set_allowed_parent!(params[:project]['parent_id']) if params[:project].has_key?('parent_id')
+ # Add current user as a project member if he is not admin
+ unless User.current.admin?
+ 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)
+ UserGrade.create(:user_id => User.current.id, :project_id => @project.id, :grade => 0)
+ if params[:project][:is_public] == '1'
+ project_status = ProjectStatus.create(:project_id => @project.id, :watchers_count => 0, :changesets_count => 0, :grade => 0, :project_type => @course_tag)
+ end
+ @project.members << m
+ @project.project_infos << project
+ end
+ respond_to do |format|
+ format.html {
+ flash[:notice] = l(:notice_successful_create)
+ if params[:continue]
+ attrs = {:parent_id => @project.parent_id}.reject {|k,v| v.nil?}
+ redirect_to new_project_path(attrs, :course => '0')
+ #Added by young
+
+ elsif params[:course_continue]
+ redirect_to new_project_path(:course => '1')
+ #Ended by young
+ else
+ redirect_to settings_project_path(@project,:project_type => 1)
+ end
+ }
+ format.api { render :action => 'show', :status => :created, :location => url_for(:controller => 'projects', :action => 'show', :id => @project.id) }
+ end
+ else
+ @course.destroy
+ respond_to do |format|
+ format.html { render :action => 'new', :layout => 'base'}#Added by young
+ format.api { render_validation_errors(@project) }
+ end
+ end
+ else
+ if validate_parent_id && @project.save
+ @project.delete
+ respond_to do |format|
+ format.html { render :action => 'new', :layout => 'base'}#Added by young
+ format.api { render_validation_errors(@project) }
+ end
+ else
+ respond_to do |format|
+ format.html { render :action => 'new', :layout => 'base'}#Added by young
+ format.api { render_validation_errors(@project) }
+ end
+ end
+ end
+ end
+ else
+ if validate_parent_id && @project.save
+ @project.set_allowed_parent!(params[:project]['parent_id']) if params[:project].has_key?('parent_id')
+ # Add current user as a project member if he is not admin
+ unless User.current.admin?
+ 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)
+ if params[:project][:is_public] == '1' || @course_tag=="1"
+ project_status = ProjectStatus.create(:project_id => @project.id, :watchers_count => 0, :changesets_count => 0)
+ end
+ @project.members << m
+ @project.project_infos << project
+ end
+ respond_to do |format|
+ format.html {
+ flash[:notice] = l(:notice_successful_create)
+ if params[:continue]
+ attrs = {:parent_id => @project.parent_id}.reject {|k,v| v.nil?}
+ redirect_to new_project_path(attrs, :course => '0')
+ #Added by young
+
+ elsif params[:course_continue]
+ redirect_to new_project_path(:course => '1')
+ #Ended by young
+ else
+ redirect_to settings_project_path(@project)
+ end
+ }
+ format.api { render :action => 'show', :status => :created, :location => url_for(:controller => 'projects', :action => 'show', :id => @project.id) }
+ end
+ else
+ respond_to do |format|
+ format.html { render :action => 'new', :layout => 'base'}#Added by young
+ format.api { render_validation_errors(@project) }
+ end
+ end
+ end
+ end
+
+ def copy
+ @issue_custom_fields = IssueCustomField.sorted.all
+ @trackers = Tracker.sorted.all
+ @source_project = Project.find(params[:id])
+ if request.get?
+ @project = Project.copy_from(@source_project)
+ @project.identifier = Project.next_identifier if Setting.sequential_project_identifiers?
+ else
+ Mailer.with_deliveries(params[:notifications] == '1') do
+ @project = Project.new
+ @project.safe_attributes = params[:project]
+ if validate_parent_id && @project.copy(@source_project, :only => params[:only])
+ @project.set_allowed_parent!(params[:project]['parent_id']) if params[:project].has_key?('parent_id')
+ flash[:notice] = l(:notice_successful_create)
+ redirect_to settings_project_path(@project)
+ elsif !@project.new_record?
+ # Project was created
+ # But some objects were not copied due to validation failures
+ # (eg. issues from disabled trackers)
+ # TODO: inform about that
+ redirect_to settings_project_path(@project)
+ end
+ end
+ end
+ rescue ActiveRecord::RecordNotFound
+ # source_project not found
+ render_404
+ end
+
+ # Show @project
+ def show
+
+ @project_type = params[:project_type]
+
+ # try to redirect to the requested menu item
+ if params[:jump] && redirect_to_project_menu_item(@project, params[:jump])
+ return
+ end
+
+ @users_by_role = @project.users_by_role
+ @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
+ if(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)
+ end
+ cond = @project.project_condition(Setting.display_subprojects_issues?)
+ @open_issues_by_tracker = Issue.visible.open.where(cond).count(:group => :tracker)
+ @total_issues_by_tracker = Issue.visible.where(cond).count(:group => :tracker)
+
+ if User.current.allowed_to?(:view_time_entries, @project)
+ @total_hours = TimeEntry.visible.sum(:hours, :include => :project, :conditions => cond).to_f
+ end
+
+ @key = User.current.rss_key
+ #新增内容
+ @days = Setting.activity_days_default.to_i
+
+ if params[:from]
+ begin; @date_to = params[:from].to_date + 1; rescue; end
+ end
+
+ has = {
+ "show_issues" => true,
+ "show_files" => true,
+ "show_documents" => true,
+ "show_messages" => true,
+ "show_news" => true,
+ "show_bids" => true
+ }
+ @date_to ||= Date.today + 1
+ @date_from = @date_to - @days
+ @with_subprojects = params[:with_subprojects].nil? ? Setting.display_subprojects_issues? : (params[:with_subprojects] == '1')
+ @author = (params[:user_id].blank? ? nil : User.active.find(params[:user_id]))
+ # 决定显示所用用户或单个用户活动
+ @activity = Redmine::Activity::Fetcher.new(User.current, :project => @project,
+ :with_subprojects => @with_subprojects,
+ :author => @author)
+ @activity.scope_select {|t| !has["show_#{t}"].nil?}
+ # @activity.scope = (@author.nil? ? :default : :all) if @activity.scope.empty?
+ #Added by young
+ events = @activity.events(@date_from, @date_to)
+
+ @offset, @limit = api_offset_and_limit({:limit => 10})
+ @events_count = events.count
+ @events_pages = Paginator.new @events_count, @limit, params['page']
+ @offset ||= @events_pages.offset
+ events = events.slice(@offset,@limit)
+ #Ended by young
+ @events_by_day = events.group_by {|event| User.current.time_to_date(event.event_datetime)}
+ # documents
+ @sort_by = %w(category date title author).include?(params[:sort_by]) ? params[:sort_by] : 'category'
+ documents = @project.documents.includes(:attachments, :category).all
+ case @sort_by
+ when 'date'
+ @grouped = documents.group_by {|d| d.updated_on.to_date }
+ when 'title'
+ @grouped = documents.group_by {|d| d.title.first.upcase}
+ when 'author'
+ @grouped = documents.select{|d| d.attachments.any?}.group_by {|d| d.attachments.last.author}
+ else
+ @grouped = documents.group_by(&:category)
+ end
+ @document = @project.documents.build
+ #
+ @base_courses_tag = @project.project_type
+ respond_to do |format|
+ format.html{render :layout => 'base_courses' if @base_courses_tag==1}
+ format.api
+ end
+ end
+
+ def settings
+ @issue_custom_fields = IssueCustomField.sorted.all
+ @issue_category ||= IssueCategory.new
+ @member ||= @project.members.new
+ @trackers = Tracker.sorted.all
+ @wiki ||= @project.wiki
+ #Added by young
+ # @course_tag = params[:course]
+ # if @course_tag == '1'
+ if @project.project_type == 1
+ @course = Course.find_by_extra(@project.identifier)
+ render :layout => 'base_courses'
+ else
+ render :layout => 'base_projects'
+ end
+ #Ended by young
+ end
+
+ def edit
+ end
+
+ #by young
+ def member
+ if @project.project_type == 1
+ render :layout => 'base_courses'
+ end
+ # roles = Role.find_all_givable
+ # members = @project.member_principals.includes(:roles, :principal).all.sort
+#
+ # users = UserGrade.find_by_sql("select * from user_grades where project_id = #{@project.id}").sort {|a,b| a[:grade] <=> b[:grade]}
+#
+ # temp = []
+ # users.each do |user|
+ # members.each do |member|
+ # if member[:user_id] == user[:user_id]
+ # temp << member
+ # end
+ # end
+ # end
+ # temps = temp.reverse
+ end
+
+ # def news
+ # if @project.project_type == 1
+ # render :layout => 'base_courses'
+ # end
+ # end
+
+ def file
+ # if @project.project_type == 1
+ # render :layout => 'base_courses'
+ # end
+ # @course_tag = params[:course]
+ # if @course_tag == '1'
+ # render :layout => 'base_courses'
+ # end
+
+ # User.current
+ end
+
+ def statistics
+
+ end
+ #end
+
+ def update
+ @project.safe_attributes = params[:project]
+ if validate_parent_id && @project.save
+ @course = Course.find_by_extra(@project.identifier)
+ unless @course.nil?
+ @course.password = params[:project][:course][:password]
+ # added by bai
+ @course.term = params[:term]
+ @course.time = params[:time]
+ # end
+ @course.save
+ end
+ @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,:grade => 0, :project_type => 1)
+ end
+
+ respond_to do |format|
+ format.html {
+ flash[:notice] = l(:notice_successful_update)
+ redirect_to settings_project_path(@project,:course => @project.project_type)
+ }
+ format.api { render_api_ok }
+ end
+ else
+ respond_to do |format|
+ format.html {
+ settings
+ render :action => 'settings'
+ }
+ format.api { render_validation_errors(@project) }
+ end
+ end
+ end
+
+ def modules
+ @project.enabled_module_names = params[:enabled_module_names]
+ flash[:notice] = l(:notice_successful_update)
+ redirect_to settings_project_path(@project, :tab => 'modules')
+ end
+
+ def archive
+ if request.post?
+ unless @project.archive
+ flash[:error] = l(:error_can_not_archive_project)
+ end
+ end
+ redirect_to admin_projects_path(:status => params[:status])
+ end
+
+ def unarchive
+ @project.unarchive if request.post? && !@project.active?
+ redirect_to admin_projects_path(:status => params[:status])
+ end
+
+ def close
+ @project.close
+ redirect_to project_path(@project)
+ end
+
+ def reopen
+ @project.reopen
+ redirect_to project_path(@project)
+ end
+
+ # Delete @project
+ def destroy
+ @project_to_destroy = @project
+ if api_request? || params[:confirm]
+ @project_to_destroy.destroy
+ respond_to do |format|
+ format.html { redirect_to admin_projects_path }
+ format.api { render_api_ok }
+ end
+ else
+ render :layout => "base"
+ end
+ # hide project in layout
+ @project = nil
+ end
+
+ private
+
+ # Validates parent_id param according to user's permissions
+ # TODO: move it to Project model in a validation that depends on User.current
+ def validate_parent_id
+ return true if User.current.admin?
+ parent_id = params[:project] && params[:project][:parent_id]
+ if parent_id || @project.new_record?
+ parent = parent_id.blank? ? nil : Project.find_by_id(parent_id.to_i)
+ unless @project.allowed_parents.include?(parent)
+ @project.errors.add :parent_id, :invalid
+ return false
+ end
+ end
+ true
+ end
+
+ # added by huang
+
+ def watcherlist
+ if @watched
+ @users -= watched.watcher_users
+ end
+ end
+end
diff --git a/app/helpers/application_helper.rb b/app/helpers/application_helper.rb
index e49e4f6d0..d916b8595 100644
--- a/app/helpers/application_helper.rb
+++ b/app/helpers/application_helper.rb
@@ -28,6 +28,8 @@ module ApplicationHelper
include AvatarHelper
## added by william
include PraiseTreadHelper
+ # add by nyan
+ include CoursesHelper
extend Forwardable
def_delegators :wiki_helper, :wikitoolbar_for, :heads_for_wiki_formatter
diff --git a/app/helpers/courses_helper.rb b/app/helpers/courses_helper.rb
new file mode 100644
index 000000000..3bdd074b8
--- /dev/null
+++ b/app/helpers/courses_helper.rb
@@ -0,0 +1,28 @@
+## This helper be included in applicationHelper
+module CoursesHelper
+ # 返回学生数量,即roles表中定义的Reporter, 返回结果 -1 为查询失败
+ def studentCount project
+ searchCountByRoles project, 5
+ end
+
+ # 返回教师数量,即roles表中定义的Manager, 返回结果 -1 为查询失败
+ def teacherCount project
+ searchCountByRoles project, 3
+ end
+
+ # 返回TA数量,即roles表中定义的TA, 返回结果 -1 为查询失败
+ def teacherAssistantCount project
+ searchCountByRoles project, 7
+ end
+
+ # 根据角色查询
+ def searchCountByRoles project, roles_id
+ count = -1
+ begin
+ count = project.members.joins(:member_roles).where("member_roles.role_id = :role_id", {:role_id => roles_id }).count
+ rescue Exception => e
+ logger.error "[CoursesHelper] ===> #{e}"
+ end
+ count
+ end
+end
diff --git a/app/views/layouts/base_courses.html.erb b/app/views/layouts/base_courses.html.erb
index b9ed0f1be..568f28472 100644
--- a/app/views/layouts/base_courses.html.erb
+++ b/app/views/layouts/base_courses.html.erb
@@ -80,13 +80,28 @@
<% files_count += version.attachments.count %>
<% end %>
- <%= link_to "#{@project.members.count}", project_member_path(@project) ,:course =>'1'%> |
-
+
+
+
+ <%= link_to "#{teacherCount(@project)}", project_member_path(@project, :role => 1) ,:course =>'1'%>
+ |
+
+ <%= link_to "#{studentCount(@project)}", project_member_path(@project, :role => 2) ,:course =>'1'%>
+ |
<%= link_to files_count, project_files_path(@project) %> |
- <%= l(:label_x_base_courses_member, :count => @project.members.count) %> |
+
+
+ <%= l(:label_x_base_courses_teacher, :count => teacherCount(@project)) %>
+ |
+
+ <%= l(:label_x_base_courses_student, :count => studentCount(@project)) %>
+
+ |
+
+ <%= l(:label_x_course_data, :count => files_count) %>
+ |
- <%= l(:label_x_course_data, :count => files_count) %> |
@@ -188,6 +203,7 @@
<%= render :partial => 'layouts/base_footer'%>
+ <%= debug(params) if Rails.env.development? %>
diff --git a/app/views/projects/member.html.erb b/app/views/projects/member.html.erb
index 9f00f25dc..944fa33be 100644
--- a/app/views/projects/member.html.erb
+++ b/app/views/projects/member.html.erb
@@ -1,6 +1,6 @@
diff --git a/config/locales/en.yml b/config/locales/en.yml
index 9098f3eea..b2d603f03 100644
--- a/config/locales/en.yml
+++ b/config/locales/en.yml
@@ -1,1545 +1,1554 @@
-en:
- # Text direction: Left-to-Right (ltr) or Right-to-Left (rtl)
- direction: ltr
- date:
- formats:
- # Use the strftime parameters for formats.
- # When no format has been given, it uses default.
- # You can provide other formats here if you like!
- default: "%m/%d/%Y"
- short: "%b %d"
- long: "%B %d, %Y"
-
- day_names: [Sunday, Monday, Tuesday, Wednesday, Thursday, Friday, Saturday]
- abbr_day_names: [Sun, Mon, Tue, Wed, Thu, Fri, Sat]
-
- # Don't forget the nil at the beginning; there's no such thing as a 0th month
- month_names: [~, January, February, March, April, May, June, July, August, September, October, November, December]
- abbr_month_names: [~, Jan, Feb, Mar, Apr, May, Jun, Jul, Aug, Sep, Oct, Nov, Dec]
- # Used in date_select and datime_select.
- order:
- - :year
- - :month
- - :day
-
- time:
- formats:
- default: "%m/%d/%Y %I:%M %p"
- time: "%I:%M %p"
- short: "%d %b %H:%M"
- long: "%B %d, %Y %H:%M"
- am: "am"
- pm: "pm"
-
- datetime:
- distance_in_words:
- half_a_minute: "half a minute"
- less_than_x_seconds:
- one: "less than 1 second"
- other: "less than %{count} seconds"
- x_seconds:
- one: "1 second"
- other: "%{count} seconds"
- less_than_x_minutes:
- one: "less than a minute"
- other: "less than %{count} minutes"
- x_minutes:
- one: "1 minute"
- other: "%{count} minutes"
- about_x_hours:
- one: "about 1 hour"
- other: "about %{count} hours"
- x_hours:
- one: "1 hour"
- other: "%{count} hours"
- x_days:
- one: "1 day"
- other: "%{count} days"
- about_x_months:
- one: "about 1 month"
- other: "about %{count} months"
- x_months:
- one: "1 month"
- other: "%{count} months"
- about_x_years:
- one: "about 1 year"
- other: "about %{count} years"
- over_x_years:
- one: "over 1 year"
- other: "over %{count} years"
- almost_x_years:
- one: "almost 1 year"
- other: "almost %{count} years"
-
- number:
- format:
- separator: "."
- delimiter: ""
- precision: 3
-
- human:
- format:
- delimiter: ""
- precision: 3
- storage_units:
- format: "%n %u"
- units:
- byte:
- one: "Byte"
- other: "Bytes"
- kb: "KB"
- mb: "MB"
- gb: "GB"
- tb: "TB"
-
-# Used in array.to_sentence.
- support:
- array:
- sentence_connector: "and"
- skip_last_comma: false
-
- activerecord:
- errors:
- template:
- header:
- one: "1 error prohibited this %{model} from being saved"
- other: "%{count} errors prohibited this %{model} from being saved"
- messages:
- inclusion: "is not included in the list"
- exclusion: "is reserved"
- invalid: "is invalid"
- confirmation: "doesn't match confirmation"
- accepted: "must be accepted"
- empty: "can't be empty"
- blank: "can't be blank"
- too_long: "is too long (maximum is %{count} characters)"
- too_short: "is too short (minimum is %{count} characters)"
- wrong_length: "is the wrong length (should be %{count} characters)"
- taken: "has already been taken"
- not_a_number: "is not a number"
- not_a_date: "is not a valid date"
- greater_than: "must be greater than %{count}"
- greater_than_or_equal_to: "must be greater than or equal to %{count}"
- equal_to: "must be equal to %{count}"
- less_than: "must be less than %{count}"
- less_than_or_equal_to: "must be less than or equal to %{count}"
- odd: "must be odd"
- even: "must be even"
- greater_than_start_date: "must be greater than start date"
- not_same_project: "doesn't belong to the same project"
- circular_dependency: "This relation would create a circular dependency"
- cant_link_an_issue_with_a_descendant: "An issue cannot be linked to one of its subtasks"
-
- actionview_instancetag_blank_option: Please select
-
- general_text_No: 'No'
- general_text_Yes: 'Yes'
- general_text_no: 'no'
- general_text_yes: 'yes'
- general_lang_name: 'English'
- general_csv_separator: ','
- general_csv_decimal_separator: '.'
- general_csv_encoding: ISO-8859-1
- general_pdf_encoding: UTF-8
- general_first_day_of_week: '7'
-
- notice_account_updated: Account was successfully updated.
- notice_account_invalid_creditentials: Invalid user or password
- notice_account_password_updated: Password was successfully updated.
- notice_account_wrong_password: Wrong password
- notice_account_register_done: Account was successfully created. To activate your account, click on the link that was emailed to you.
- notice_account_unknown_email: Unknown user.
- notice_can_t_change_password: This account uses an external authentication source. Impossible to change the password.
- notice_account_lost_email_sent: An email with instructions to choose a new password has been sent to you.
- notice_account_activated: Your account has been activated. You can now log in.
- notice_successful_create: Successful creation.
- notice_successful_update: Successful update.
- notice_successful_delete: Successful deletion.
- notice_successful_connection: Successful connection.
- notice_file_not_found: The page you were trying to access doesn't exist or has been removed.
- notice_locking_conflict: Data has been updated by another user.
- notice_not_authorized: You are not authorized to access this page.
- notice_not_authorized_archived_project: The project you're trying to access has been archived.
- notice_email_sent: "An email was sent to %{value}"
- notice_email_error: "An error occurred while sending mail (%{value})"
- notice_feeds_access_key_reseted: Your RSS access key was reset.
- notice_api_access_key_reseted: Your API access key was reset.
- notice_failed_to_save_issues: "Failed to save %{count} issue(s) on %{total} selected: %{ids}."
- notice_failed_to_save_time_entries: "Failed to save %{count} time entrie(s) on %{total} selected: %{ids}."
- notice_failed_to_save_members: "Failed to save member(s): %{errors}."
- notice_no_issue_selected: "No issue is selected! Please, check the issues you want to edit."
- notice_account_pending: "Your account was created and is now pending administrator approval."
- notice_default_data_loaded: Default configuration successfully loaded.
- notice_unable_delete_version: Unable to delete version.
- notice_unable_delete_time_entry: Unable to delete time log entry.
- notice_issue_done_ratios_updated: Issue done ratios updated.
- notice_gantt_chart_truncated: "The chart was truncated because it exceeds the maximum number of items that can be displayed (%{max})"
- notice_issue_successful_create: "Issue %{id} created."
- notice_issue_update_conflict: "The issue has been updated by an other user while you were editing it."
- notice_account_deleted: "Your account has been permanently deleted."
- notice_user_successful_create: "User %{id} created."
-
- error_can_t_load_default_data: "Default configuration could not be loaded: %{value}"
- error_scm_not_found: "The entry or revision was not found in the repository."
- error_scm_command_failed: "An error occurred when trying to access the repository: %{value}"
- error_scm_annotate: "The entry does not exist or cannot be annotated."
- error_scm_annotate_big_text_file: "The entry cannot be annotated, as it exceeds the maximum text file size."
- error_issue_not_found_in_project: 'The issue was not found or does not belong to this project'
- error_no_tracker_in_project: 'No tracker is associated to this project. Please check the Project settings.'
- error_no_default_issue_status: 'No default issue status is defined. Please check your configuration (Go to "Administration -> Issue statuses").'
- error_can_not_delete_custom_field: Unable to delete custom field
- error_can_not_delete_tracker: "This tracker contains issues and cannot be deleted."
- error_can_not_remove_role: "This role is in use and cannot be deleted."
- error_can_not_reopen_issue_on_closed_version: 'An issue assigned to a closed version cannot be reopened'
- error_can_not_archive_project: This project cannot be archived
- error_issue_done_ratios_not_updated: "Issue done ratios not updated."
- error_workflow_copy_source: 'Please select a source tracker or role'
- error_workflow_copy_target: 'Please select target tracker(s) and role(s)'
- error_unable_delete_issue_status: 'Unable to delete issue status'
- error_unable_to_connect: "Unable to connect (%{value})"
- error_attachment_too_big: "This file cannot be uploaded because it exceeds the maximum allowed file size (%{max_size})"
- error_session_expired: "Your session has expired. Please login again."
- warning_attachments_not_saved: "%{count} file(s) could not be saved."
-
- mail_subject_lost_password: "Your %{value} password"
- mail_body_lost_password: 'To change your password, click on the following link:'
- mail_subject_register: "Your %{value} account activation"
- mail_body_register: 'To activate your account, click on the following link:'
- mail_body_account_information_external: "You can use your %{value} account to log in."
- mail_body_account_information: Your account information
- mail_subject_account_activation_request: "%{value} account activation request"
- mail_body_account_activation_request: "A new user (%{value}) has registered. The account is pending your approval:"
- mail_subject_reminder: "%{count} issue(s) due in the next %{days} days"
- mail_body_reminder: "%{count} issue(s) that are assigned to you are due in the next %{days} days:"
- mail_subject_wiki_content_added: "'%{id}' wiki page has been added"
- mail_body_wiki_content_added: "The '%{id}' wiki page has been added by %{author}."
- mail_subject_wiki_content_updated: "'%{id}' wiki page has been updated"
- mail_body_wiki_content_updated: "The '%{id}' wiki page has been updated by %{author}."
-
- field_name: Name
- field_description: Description
- field_summary: Summary
- field_is_required: Required
- field_firstname: First name
- field_lastname: Last name
- field_mail: Email
- field_job_category: Job category # added by bai
- field_filename: File
- field_filesize: Size
- field_downloads: Downloads
- field_author: Author
- field_created_on: Created
- field_updated_on: Updated
- field_closed_on: Closed
- field_field_format: Format
- field_is_for_all: For all projects
- field_possible_values: Possible values
- field_regexp: Regular expression
- field_min_length: Minimum length
- field_max_length: Maximum length
- field_value: Value
- field_category: Category
- field_title: Title
- field_project: Project
- field_issue: Issue
- field_status: Status
- field_notes: Notes
- field_is_closed: Issue closed
- field_is_default: Default value
- field_tracker: Tracker
- field_subject: Subject
- field_due_date: Due date
- field_assigned_to: Assignee
- field_priority: Priority
- field_fixed_version: Target version
- field_user: User
- field_principal: Principal
- field_role: Role
- field_homepage: Homepage
- field_is_public: Public
- field_parent: Subproject of
- field_is_in_roadmap: Issues displayed in roadmap
- field_login: Login
- field_mail_notification: Email notifications
- field_admin: Administrator
- field_last_login_on: Last connection
- field_language: Language
- field_effective_date: Date
- field_password: Password
- field_new_password: New password
- field_password_confirmation: Confirmation
- field_version: Version
- field_type: Type
- field_host: Host
- field_port: Port
- field_account: Account
- field_base_dn: Base DN
- field_attr_login: Login attribute
- field_attr_firstname: Firstname attribute
- field_attr_lastname: Lastname attribute
- field_attr_mail: Email attribute
- field_onthefly: On-the-fly user creation
- field_start_date: Start date
- field_done_ratio: "% Done"
- field_auth_source: Authentication mode
- field_hide_mail: Hide my email address
- field_comments: Comment
- field_url: URL
- field_start_page: Start page
- field_subproject: Subproject
- field_hours: Hours
- field_activity: Activity
- field_spent_on: Date
- field_identifier: Identifier
- field_is_filter: Used as a filter
- field_issue_to: Related issue
- field_delay: Delay
- field_assignable: Issues can be assigned to this role
- field_redirect_existing_links: Redirect existing links
- field_estimated_hours: Estimated time
- field_column_names: Columns
- field_time_entries: Log time
- field_time_zone: Time zone
- field_searchable: Searchable
- field_default_value: Default value
- field_comments_sorting: Display comments
- field_parent_title: Parent page
- field_editable: Editable
- field_watcher: Watcher
- field_identity_url: OpenID URL
- field_content: Content
- field_group_by: Group results by
- field_sharing: Sharing
- field_parent_issue: Parent task
- field_member_of_group: "Assignee's group"
- field_assigned_to_role: "Assignee's role"
- field_text: Text field
- field_visible: Visible
- field_warn_on_leaving_unsaved: "Warn me when leaving a page with unsaved text"
- field_issues_visibility: Issues visibility
- field_is_private: Private
- field_commit_logs_encoding: Commit messages encoding
- field_scm_path_encoding: Path encoding
- field_path_to_repository: Path to repository
- field_root_directory: Root directory
- field_cvsroot: CVSROOT
- field_cvs_module: Module
- field_repository_is_default: Main repository
- field_multiple: Multiple values
- field_auth_source_ldap_filter: LDAP filter
- field_core_fields: Standard fields
- field_timeout: "Timeout (in seconds)"
- field_board_parent: Parent forum
- field_private_notes: Private notes
- field_inherit_members: Inherit members
-
- setting_app_title: Application title
- setting_app_subtitle: Application subtitle
- setting_welcome_text: Welcome text
- setting_default_language: Default language
- setting_login_required: Authentication required
- setting_self_registration: Self-registration
- setting_attachment_max_size: Maximum attachment size
- setting_issues_export_limit: Issues export limit
- setting_mail_from: Emission email address
- setting_bcc_recipients: Blind carbon copy recipients (bcc)
- setting_plain_text_mail: Plain text mail (no HTML)
- setting_host_name: Host name and path
- setting_text_formatting: Text formatting
- setting_wiki_compression: Wiki history compression
- setting_feeds_limit: Maximum number of items in Atom feeds
- setting_default_projects_public: New projects are public by default
- setting_autofetch_changesets: Fetch commits automatically
- setting_sys_api_enabled: Enable WS for repository management
- setting_commit_ref_keywords: Referencing keywords
- setting_commit_fix_keywords: Fixing keywords
- setting_autologin: Autologin
- setting_date_format: Date format
- setting_time_format: Time format
- setting_cross_project_issue_relations: Allow cross-project issue relations
- setting_cross_project_subtasks: Allow cross-project subtasks
- setting_issue_list_default_columns: Default columns displayed on the issue list
- setting_repositories_encodings: Attachments and repositories encodings
- setting_emails_header: Email header
- setting_emails_footer: Email footer
- setting_protocol: Protocol
- setting_per_page_options: Objects per page options
- setting_user_format: Users display format
- setting_activity_days_default: Days displayed on project activity
- setting_display_subprojects_issues: Display subprojects issues on main projects by default
- setting_enabled_scm: Enabled SCM
- setting_mail_handler_body_delimiters: "Truncate emails after one of these lines"
- setting_mail_handler_api_enabled: Enable WS for incoming emails
- setting_mail_handler_api_key: API key
- setting_sequential_project_identifiers: Generate sequential project identifiers
- setting_gravatar_enabled: Use Gravatar user icons
- setting_gravatar_default: Default Gravatar image
- setting_diff_max_lines_displayed: Maximum number of diff lines displayed
- setting_file_max_size_displayed: Maximum size of text files displayed inline
- setting_repository_log_display_limit: Maximum number of revisions displayed on file log
- setting_openid: Allow OpenID login and registration
- setting_password_min_length: Minimum password length
- setting_new_project_user_role_id: Role given to a non-admin user who creates a project
- setting_default_projects_modules: Default enabled modules for new projects
- setting_issue_done_ratio: Calculate the issue done ratio with
- setting_issue_done_ratio_issue_field: Use the issue field
- setting_issue_done_ratio_issue_status: Use the issue status
- setting_start_of_week: Start calendars on
- setting_rest_api_enabled: Enable REST web service
- setting_cache_formatted_text: Cache formatted text
- setting_default_notification_option: Default notification option
- setting_commit_logtime_enabled: Enable time logging
- setting_commit_logtime_activity_id: Activity for logged time
- setting_gantt_items_limit: Maximum number of items displayed on the gantt chart
- setting_issue_group_assignment: Allow issue assignment to groups
- setting_default_issue_start_date_to_creation_date: Use current date as start date for new issues
- setting_commit_cross_project_ref: Allow issues of all the other projects to be referenced and fixed
- setting_unsubscribe: Allow users to delete their own account
- setting_session_lifetime: Session maximum lifetime
- setting_session_timeout: Session inactivity timeout
- setting_thumbnails_enabled: Display attachment thumbnails
- setting_thumbnails_size: Thumbnails size (in pixels)
- setting_non_working_week_days: Non-working days
- setting_jsonp_enabled: Enable JSONP support
- setting_default_projects_tracker_ids: Default trackers for new projects
-
- permission_add_project: Create project
- permission_add_subprojects: Create subprojects
- permission_edit_project: Edit project
- permission_close_project: Close / reopen the project
- permission_select_project_modules: Select project modules
- permission_manage_members: Manage members
- permission_manage_project_activities: Manage project activities
- permission_manage_versions: Manage versions
- permission_manage_categories: Manage issue categories
- permission_view_issues: View Issues
- permission_add_issues: Add issues
- permission_edit_issues: Edit issues
- permission_manage_issue_relations: Manage issue relations
- permission_set_issues_private: Set issues public or private
- permission_set_own_issues_private: Set own issues public or private
- permission_add_issue_notes: Add notes
- permission_edit_issue_notes: Edit notes
- permission_edit_own_issue_notes: Edit own notes
- permission_view_private_notes: View private notes
- permission_set_notes_private: Set notes as private
- permission_move_issues: Move issues
- permission_delete_issues: Delete issues
- permission_manage_public_queries: Manage public queries
- permission_save_queries: Save queries
- permission_view_gantt: View gantt chart
- permission_view_calendar: View calendar
- permission_view_issue_watchers: View watchers list
- permission_add_issue_watchers: Add watchers
- permission_delete_issue_watchers: Delete watchers
- permission_log_time: Log spent time
- permission_view_time_entries: View spent time
- permission_edit_time_entries: Edit time logs
- permission_edit_own_time_entries: Edit own time logs
- permission_manage_news: Manage news
- permission_comment_news: Comment news
- permission_view_documents: View documents
- permission_add_documents: Add documents
- permission_edit_documents: Edit documents
- permission_delete_documents: Delete documents
- permission_manage_files: Manage files
- permission_view_files: View files
- permission_manage_wiki: Manage wiki
- permission_rename_wiki_pages: Rename wiki pages
- permission_delete_wiki_pages: Delete wiki pages
- permission_view_wiki_pages: View wiki
- permission_view_wiki_edits: View wiki history
- permission_edit_wiki_pages: Edit wiki pages
- permission_delete_wiki_pages_attachments: Delete attachments
- permission_protect_wiki_pages: Protect wiki pages
- permission_manage_repository: Manage repository
- permission_browse_repository: Browse repository
- permission_view_changesets: View changesets
- permission_commit_access: Commit access
- permission_manage_boards: Manage forums
- permission_view_messages: View messages
- permission_add_messages: Post messages
- permission_edit_messages: Edit messages
- permission_edit_own_messages: Edit own messages
- permission_delete_messages: Delete messages
- permission_delete_own_messages: Delete own messages
- permission_export_wiki_pages: Export wiki pages
- permission_manage_subtasks: Manage subtasks
- permission_manage_related_issues: Manage related issues
-
- project_module_issue_tracking: Issue tracking
- project_module_time_tracking: Time tracking
- project_module_news: News
- project_module_documents: Documents
- project_module_files: Files
- project_module_wiki: Wiki
- project_module_repository: Repository
- project_module_boards: Forums
- project_module_calendar: Calendar
- project_module_gantt: Gantt
-
- label_user: User
- label_user_plural: Users
- label_user_new: New user
- label_user_anonymous: Anonymous
- label_project: Project
- label_activity_project: 'Project: ' #added by bai
- label_project_new: New project
- label_project_plural: Projects
- label_x_projects:
- zero: no projects
- one: 1 project
- other: "%{count} projects"
- label_project_all: All Projects
- label_project_latest: Latest projects
- label_issue: Issue
- label_issue_new: New issue
- label_issue_plural: Issues
- label_issue_view_all: View all issues
- label_issues_by: "Issues by %{value}"
- label_issue_added: Issue added
- label_issue_updated: Issue updated
- label_issue_note_added: Note added
- label_issue_status_updated: Status updated
- label_issue_priority_updated: Priority updated
- label_document: Document
- label_document_new: New document
- label_document_plural: Documents
- label_document_added: Document added
- label_role: Role
- label_role_plural: Roles
- label_role_new: New role
- label_role_and_permissions: Roles and permissions
- label_role_anonymous: Anonymous
- label_role_non_member: Non member
- label_member: Members
- label_member_new: New member
- label_member_plural: Members
- label_tracker: Tracker
- label_tracker_plural: Trackers
- label_tracker_new: New tracker
- label_workflow: Workflow
- label_issue_status: Issue status
- label_issue_status_plural: Issue statuses
- label_issue_status_new: New status
- label_issue_category: Issue category
- label_issue_category_plural: Issue categories
- label_issue_category_new: New category
- label_custom_field: Custom field
- label_custom_field_plural: Custom fields
- label_custom_field_new: New custom field
- label_enumerations: Enumerations
- label_enumeration_new: New value
- label_information: Information
- label_information_plural: Information
- label_please_login: Please log in
- label_register: Sign up
- label_login_with_open_id_option: or login with OpenID
- label_password_lost: Lost password
- label_home: Home
- label_my_page: My page
- label_my_account: My account
- label_my_projects: My projects
- label_my_page_block: My page block
- label_administration: Administration
- label_login: Login
- label_logout: Sign out
- label_help: Help
- label_reported_issues: Reported issues
- label_assigned_to_me_issues: Issues assigned to me
- label_last_login: Last connection
- label_registered_on: Registered on
- label_activity: Activities
- label_overall_activity: Overall activity
- label_user_activity: "%{value}'s activity"
- label_new: New
- label_new_user: registered a new account
- label_logged_as: Logged in as
- label_environment: Environment
- label_authentication: Authentication
- label_auth_source: Authentication mode
- label_auth_source_new: New authentication mode
- label_auth_source_plural: Authentication modes
- label_subproject_plural: Subprojects
- label_subproject_new: New subproject
- label_and_its_subprojects: "%{value} and its subprojects"
- label_min_max_length: Min - Max length
- label_list: List
- label_date: Date
- label_integer: Integer
- label_float: Float
- label_boolean: Boolean
- label_string: Text
- label_text: Long text
- label_attribute: Attribute
- label_attribute_plural: Attributes
- label_no_data: No data to display
- label_change_status: Change status
- label_history: History
- label_attachment: Files
- label_attachment_new: New file
- label_attachment_delete: Delete file
- label_attachment_plural: Files
- label_file_added: File added
- label_report: Report
- label_report_plural: Reports
- label_news: News
- label_news_new: Add news
- label_news_plural: News
- label_news_latest: Latest news
- label_news_view_all: View all news
- label_news_added: News added
- label_news_comment_added: Comment added to a news
- label_settings: Settings
- label_overview: Activities
- label_version: Version
- label_version_new: New version
- label_version_plural: Versions
- label_close_versions: Close completed versions
- label_confirmation: Confirmation
- label_export_to: 'Also available in:'
- label_read: Read...
- label_public_projects: Public projects
- label_open_issues: open
- label_open_issues_plural: open
- label_closed_issues: closed
- label_closed_issues_plural: closed
- label_x_open_issues_abbr_on_total:
- zero: 0 open / %{total}
- one: 1 open / %{total}
- other: "%{count} open / %{total}"
- label_x_open_issues_abbr:
- zero: 0 open
- one: 1 open
- other: "%{count} open"
- label_x_closed_issues_abbr:
- zero: 0 closed
- one: 1 closed
- other: "%{count} closed"
- label_x_issues:
- zero: 0 issues
- one: 1 issue
- other: "%{count} issues"
- label_total: Total
- label_total_time: Total time
- label_permissions: Permissions
- label_current_status: Current status
- label_new_statuses_allowed: New statuses allowed
- label_all: all
- label_any: any
- label_none: none
- label_nobody: nobody
- label_next: Next
- label_previous: Previous
- label_used_by: Used by
- label_details: Details
- label_add_note: Add a note
- label_per_page: Per page
- label_calendar: Calendar
- label_months_from: months from
- label_gantt: Gantt
- label_internal: Internal
- label_last_changes: "last %{count} changes"
- label_change_view_all: View all changes
- label_personalize_page: Personalize this page
- label_comment: Comment
- label_comment_plural: Comments
- label_x_comments:
- zero: no comments
- one: 1 comment
- other: "%{count} comments"
- label_comment_add: Add a comment
- label_comment_added: Comment added
- label_comment_delete: Delete comments
- label_query: Custom query
- label_query_plural: Custom queries
- label_query_new: New query
- label_my_queries: My custom queries
- label_filter_add: Add filter
- label_filter_plural: Query condition
- label_equals: is
- label_not_equals: is not
- label_in_less_than: in less than
- label_in_more_than: in more than
- label_in_the_next_days: in the next
- label_in_the_past_days: in the past
- label_in_users: 'in the user '
- label_greater_or_equal: '>='
- label_less_or_equal: '<='
- label_between: between
- label_in: in
- label_today: today
- label_all_time: all time
- label_yesterday: yesterday
- label_this_week: this week
- label_last_week: last week
- label_last_n_weeks: "last %{count} weeks"
- label_last_n_days: "last %{count} days"
- label_this_month: this month
- label_last_month: last month
- label_this_year: this year
- label_date_range: Date range
- label_less_than_ago: less than days ago
- label_more_than_ago: more than days ago
- label_ago: days ago
- label_contains: contains
- label_not_contains: doesn't contain
- label_any_issues_in_project: any issues in project
- label_any_issues_not_in_project: any issues not in project
- label_no_issues_in_project: no issues in project
- label_day_plural: days
- label_repository: Repository
- #add by tan
- label_repository_new: Repository setting
- label_repository_no: Have no repository?
- label_repository_new_repos: New repository
- #end
- label_repository_plural: Repositories
- label_browse: Browse
- label_branch: Branch
- label_tag: Tag
- label_revision: Revision
- label_revision_plural: Revisions
- label_revision_id: "Revision %{value}"
- label_associated_revisions: Associated revisions
- label_added: added
- label_modified: modified
- label_copied: copied
- label_renamed: renamed
- label_deleted: deleted
- label_latest_revision: Latest revision
- label_latest_revision_plural: Latest revisions
- label_view_revisions: View revisions
- label_view_all_revisions: View all revisions
- label_max_size: Maximum size
- label_sort_highest: Move to top
- label_sort_higher: Move up
- label_sort_lower: Move down
- label_sort_lowest: Move to bottom
- label_roadmap: Roadmap
- label_roadmap_due_in: "Due in %{value}"
- label_roadmap_overdue: "%{value} late"
- label_roadmap_no_issues: No issues for this version
- label_search: Search
- label_result_plural: Results
- label_all_words: All words
- label_wiki: Wiki
- label_wiki_edit: Wiki edit
- label_wiki_edit_plural: Wiki edits
- label_wiki_page: Wiki page
- label_wiki_page_plural: Wiki pages
- label_index_by_title: Index by title
- label_index_by_date: Index by date
- label_current_version: Current version
- label_preview: Preview
- label_feed_plural: Feeds
- label_changes_details: Details of all changes
- label_issue_tracking: Issue tracking
- label_spent_time: Spent time
- label_overall_spent_time: Overall spent time
- label_f_hour: "%{value} hour"
- label_f_hour_plural: "%{value} hours"
- label_time_tracking: Time tracking
- label_change_plural: Changes
- label_statistics: Statistics
- label_commits_per_month: Commits per month
- label_commits_per_author: Commits per author
- label_diff: diff
- label_view_diff: View differences
- label_diff_inline: inline
- label_diff_side_by_side: side by side
- label_options: Options
- label_copy_workflow_from: Copy workflow from
- label_permissions_report: Permissions report
- label_watched_issues: Watched issues
- label_related_issues: Related issues
- label_applied_status: Applied status
- label_loading: Loading...
- label_relation_new: New relation
- label_relation_delete: Delete relation
- label_relates_to: Related to
- label_duplicates: Duplicates
- label_duplicated_by: Duplicated by
- label_blocks: Blocks
- label_blocked_by: Blocked by
- label_precedes: Precedes
- label_follows: Follows
- label_copied_to: Copied to
- label_copied_from: Copied from
- label_end_to_start: end to start
- label_end_to_end: end to end
- label_start_to_start: start to start
- label_start_to_end: start to end
- label_stay_logged_in: Stay logged in
- label_disabled: disabled
- label_show_completed_versions: Show completed versions
- label_me: me
- label_board: Forums
- label_board_description: Bring together the wisdom of crowds, and solve problems for you!
- label_board_new: New forum
- label_board_plural: Forums
- label_board_locked: Locked
- label_board_sticky: Sticky
- label_topic_plural: Topics
- label_message_plural: Messages
- label_message_last: Last message
- label_message_new: New message
- label_message_posted: Message added
- label_reply_plural: Replies
- label_send_information: Send account information to the user
- label_year: Year
- label_month: Month
- label_week: Week
- label_date_from: From
- label_date_to: To
- label_language_based: Based on user's language
- label_sort_by: "Sort by %{value}"
- label_send_test_email: Send a test email
- label_feeds_access_key: RSS access key
- label_missing_feeds_access_key: Missing a RSS access key
- label_feeds_access_key_created_on: "RSS access key created %{value} ago"
- label_module_plural: Modules
- label_added_time_by: "Added by %{author} %{age} ago"
- label_updated_time_by: "Updated by %{author} %{age} ago"
- label_updated_time: "Updated %{value} ago"
- label_jump_to_a_project: Jump to a project...
- label_file_plural: Files
- label_changeset_plural: Changesets
- label_default_columns: Default columns
- label_no_change_option: (No change)
- label_bulk_edit_selected_issues: Bulk edit selected issues
- label_bulk_edit_selected_time_entries: Bulk edit selected time entries
- label_theme: Theme
- label_default: Default
- label_search_titles_only: Search titles only
- label_user_mail_option_all: "For any event on all my projects"
- label_user_mail_option_selected: "For any event on the selected projects only..."
- label_user_mail_option_none: "No events"
- label_user_mail_option_only_my_events: "Only for things I watch or I'm involved in"
- label_user_mail_option_only_assigned: "Only for things I am assigned to"
- label_user_mail_option_only_owner: "Only for things I am the owner of"
- label_user_mail_no_self_notified: "I don't want to be notified of changes that I make myself"
- label_registration_activation_by_email: account activation by email
- label_registration_manual_activation: manual account activation
- label_registration_automatic_activation: automatic account activation
- label_display_per_page: "Per page: %{value}"
- label_age: Age
- label_change_properties: Change properties
- label_general: General
- label_more: More
- label_scm: SCM
- label_plugins: Plugins
- label_ldap_authentication: LDAP authentication
- label_downloads_abbr: D/L
- label_optional_description: Optional description
- label_add_another_file: Add another file
- label_preferences: Preferences
- label_chronological_order: In chronological order
- label_reverse_chronological_order: In reverse chronological order
- label_planning: Planning
- label_incoming_emails: Incoming emails
- label_generate_key: Generate a key
- label_issue_watchers: Watchers
- label_example: Example
- label_display: Display
- label_sort: Sort
- label_ascending: Ascending
- label_descending: Descending
- label_date_from_to: From %{start} to %{end}
- label_wiki_content_added: Wiki page added
- label_wiki_content_updated: Wiki page updated
- label_group: Group
- label_group_plural: Groups
- label_group_new: New group
- label_time_entry_plural: Spent time
- label_version_sharing_none: Not shared
- label_version_sharing_descendants: With subprojects
- label_version_sharing_hierarchy: With project hierarchy
- label_version_sharing_tree: With project tree
- label_version_sharing_system: With all projects
- label_update_issue_done_ratios: Update issue done ratios
- label_copy_source: Source
- label_copy_target: Target
- label_copy_same_as_target: Same as target
- label_display_used_statuses_only: Only display statuses that are used by this tracker
- label_api_access_key: API access key
- label_missing_api_access_key: Missing an API access key
- label_api_access_key_created_on: "API access key created %{value} ago"
- label_profile: Profile
- label_subtask_plural: Subtasks
- label_project_copy_notifications: Send email notifications during the project copy
- label_principal_search: "Search for user or group:"
- label_user_search: "Search for user:"
- label_additional_workflow_transitions_for_author: Additional transitions allowed when the user is the author
- label_additional_workflow_transitions_for_assignee: Additional transitions allowed when the user is the assignee
- label_issues_visibility_all: All issues
- label_issues_visibility_public: All non private issues
- label_issues_visibility_own: Issues created by or assigned to the user
- label_git_report_last_commit: Report last commit for files and directories
- label_parent_revision: Parent
- label_child_revision: Child
- label_export_options: "%{export_format} export options"
- label_copy_attachments: Copy attachments
- label_copy_subtasks: Copy subtasks
- label_item_position: "%{position} of %{count}"
- label_completed_versions: Completed versions
- label_search_for_watchers: Search for watchers to add
- label_session_expiration: Session expiration
- label_show_closed_projects: View closed projects
- label_status_transitions: Status transitions
- label_fields_permissions: Fields permissions
- label_readonly: Read-only
- label_required: Required
- label_attribute_of_project: "Project's %{name}"
- label_attribute_of_issue: "Issue's %{name}"
- label_attribute_of_author: "Author's %{name}"
- label_attribute_of_assigned_to: "Assignee's %{name}"
- label_attribute_of_user: "User's %{name}"
- label_attribute_of_fixed_version: "Target version's %{name}"
- label_cross_project_descendants: With subprojects
- label_cross_project_tree: With project tree
- label_cross_project_hierarchy: With project hierarchy
- label_cross_project_system: With all projects
- label_gantt_progress_line: Progress line
-
- button_login: Login
- button_submit: Submit
- button_save: Save
- button_check_all: Check all
- button_uncheck_all: Uncheck all
- button_collapse_all: Collapse all
- button_expand_all: Expand all
- button_delete: Delete
- button_create: Create
- button_create_and_continue: Create and continue
- button_test: Test
- button_edit: Edit
- button_edit_associated_wikipage: "Edit associated Wiki page: %{page_title}"
- button_add: Add
- button_change: Change
- button_apply: Query
- button_clear: Cancel query
- button_lock: Lock
- button_unlock: Unlock
- button_download: Download
- button_list: List
- button_view: View
- button_move: Move
- button_move_and_follow: Move and follow
- button_back: Back
- button_cancel: Cancel
- button_activate: Activate
- button_sort: Sort
- button_log_time: Log time
- button_rollback: Rollback to this version
- button_watch: Watch
- button_unwatch: Unwatch
- button_reply: Reply
- button_archive: Archive
- button_unarchive: Unarchive
- button_reset: Reset
- button_rename: Rename
- button_change_password: Change password
- button_copy: Copy
- button_copy_and_follow: Copy and follow
- button_annotate: Annotate
- button_update: Update
- button_configure: Configure
- button_quote: Quote
- button_duplicate: Duplicate
- button_show: Show
- button_hide: Hide
- button_edit_section: Edit this section
- button_export: Export
- button_delete_my_account: Delete my account
- button_close: Close
- button_reopen: Reopen
-
- status_active: active
- status_registered: registered
- status_locked: locked
-
- project_status_active: active
- project_status_closed: closed
- project_status_archived: archived
-
- version_status_open: open
- version_status_locked: locked
- version_status_closed: closed
-
- field_active: Active
-
- text_select_mail_notifications: Select actions for which email notifications should be sent.
- text_regexp_info: eg. ^[A-Z0-9]+$
- text_min_max_length_info: 0 means no restriction
- text_project_destroy_confirmation: Are you sure you want to delete this project and related data?
- text_subprojects_destroy_warning: "Its subproject(s): %{value} will be also deleted."
- text_workflow_edit: Select a role and a tracker to edit the workflow
- text_are_you_sure: Are you sure?
- text_journal_changed: "%{label} changed from %{old} to %{new}"
- text_journal_changed_no_detail: "%{label} updated"
- text_journal_set_to: "%{label} set to %{value}"
- text_journal_deleted: "%{label} deleted (%{old})"
- text_journal_added: "%{label} %{value} added"
- text_tip_issue_begin_day: issue beginning this day
- text_tip_issue_end_day: issue ending this day
- text_tip_issue_begin_end_day: issue beginning and ending this day
- text_project_identifier_info: 'Only lower case letters (a-z), numbers, dashes and underscores are allowed, must start with a lower case letter.
Once saved, the identifier cannot be changed.'
- text_caracters_maximum: "%{count} characters maximum."
- text_caracters_minimum: "Must be at least %{count} characters long."
- text_length_between: "Length between %{min} and %{max} characters."
- text_tracker_no_workflow: No workflow defined for this tracker
- text_unallowed_characters: Unallowed characters
- text_comma_separated: Multiple values allowed (comma separated).
- text_line_separated: Multiple values allowed (one line for each value).
- text_issues_ref_in_commit_messages: Referencing and fixing issues in commit messages
- text_issue_added: "Issue %{id} has been reported by %{author}."
- text_issue_updated: "Issue %{id} has been updated by %{author}."
- text_wiki_destroy_confirmation: Are you sure you want to delete this wiki and all its content?
- text_issue_category_destroy_question: "Some issues (%{count}) are assigned to this category. What do you want to do?"
- text_issue_category_destroy_assignments: Remove category assignments
- text_issue_category_reassign_to: Reassign issues to this category
- text_user_mail_option: "For unselected projects, you will only receive notifications about things you watch or you're involved in (eg. issues you're the author or assignee)."
- text_no_configuration_data: "Roles, trackers, issue statuses and workflow have not been configured yet.\nIt is highly recommended to load the default configuration. You will be able to modify it once loaded."
- text_load_default_configuration: Load the default configuration
- text_status_changed_by_changeset: "Applied in changeset %{value}."
- text_time_logged_by_changeset: "Applied in changeset %{value}."
- text_issues_destroy_confirmation: 'Are you sure you want to delete the selected issue(s)?'
- text_issues_destroy_descendants_confirmation: "This will also delete %{count} subtask(s)."
- text_time_entries_destroy_confirmation: 'Are you sure you want to delete the selected time entr(y/ies)?'
- text_select_project_modules: 'Select modules to enable for this project:'
- text_default_administrator_account_changed: Default administrator account changed
- text_file_repository_writable: Attachments directory writable
- text_plugin_assets_writable: Plugin assets directory writable
- text_rmagick_available: RMagick available (optional)
- text_destroy_time_entries_question: "%{hours} hours were reported on the issues you are about to delete. What do you want to do?"
- text_destroy_time_entries: Delete reported hours
- text_assign_time_entries_to_project: Assign reported hours to the project
- text_reassign_time_entries: 'Reassign reported hours to this issue:'
- text_user_wrote: "%{value} wrote:"
- text_enumeration_destroy_question: "%{count} objects are assigned to this value."
- text_enumeration_category_reassign_to: 'Reassign them to this value:'
- text_email_delivery_not_configured: "Email delivery is not configured, and notifications are disabled.\nConfigure your SMTP server in config/configuration.yml and restart the application to enable them."
- text_repository_usernames_mapping: "Select or update the Redmine user mapped to each username found in the repository log.\nUsers with the same Redmine and repository username or email are automatically mapped."
- text_diff_truncated: '... This diff was truncated because it exceeds the maximum size that can be displayed.'
- text_custom_field_possible_values_info: 'One line for each value'
- text_wiki_page_destroy_question: "This page has %{descendants} child page(s) and descendant(s). What do you want to do?"
- text_wiki_page_nullify_children: "Keep child pages as root pages"
- text_wiki_page_destroy_children: "Delete child pages and all their descendants"
- text_wiki_page_reassign_children: "Reassign child pages to this parent page"
- text_own_membership_delete_confirmation: "You are about to remove some or all of your permissions and may no longer be able to edit this project after that.\nAre you sure you want to continue?"
- text_zoom_in: Zoom in
- text_zoom_out: Zoom out
- text_warn_on_leaving_unsaved: "The current page contains unsaved text that will be lost if you leave this page."
- text_scm_path_encoding_note: "Default: UTF-8"
- text_git_repository_note: Repository is bare and local (e.g. /gitrepo, c:\gitrepo)
- text_mercurial_repository_note: Local repository (e.g. /hgrepo, c:\hgrepo)
- text_scm_command: Command
- text_scm_command_version: Version
- text_scm_config: You can configure your SCM commands in config/configuration.yml. Please restart the application after editing it.
- text_scm_command_not_available: SCM command is not available. Please check settings on the administration panel.
- text_issue_conflict_resolution_overwrite: "Apply my changes anyway (previous notes will be kept but some changes may be overwritten)"
- text_issue_conflict_resolution_add_notes: "Add my notes and discard my other changes"
- text_issue_conflict_resolution_cancel: "Discard all my changes and redisplay %{link}"
- text_account_destroy_confirmation: "Are you sure you want to proceed?\nYour account will be permanently deleted, with no way to reactivate it."
- text_session_expiration_settings: "Warning: changing these settings may expire the current sessions including yours."
- text_project_closed: This project is closed and read-only.
- text_turning_multiple_off: "If you disable multiple values, multiple values will be removed in order to preserve only one value per item."
-
- default_role_manager: Manager
- default_role_developer: Developer
- default_role_reporter: Reporter
- default_tracker_bug: Bug
- default_tracker_feature: Feature
- default_tracker_support: Support
- default_issue_status_new: New
- default_issue_status_in_progress: In Progress
- default_issue_status_resolved: Resolved
- default_issue_status_feedback: Feedback
- default_issue_status_closed: Closed
- default_issue_status_rejected: Rejected
- default_doc_category_user: User documentation
- default_doc_category_tech: Technical documentation
- default_priority_low: Low
- default_priority_normal: Normal
- default_priority_high: High
- default_priority_urgent: Urgent
- default_priority_immediate: Immediate
- default_activity_design: Design
- default_activity_development: Development
-
- enumeration_issue_priorities: Issue priorities
- enumeration_doc_categories: Document categories
- enumeration_activities: Activities
- enumeration_system_activity: System Activity
- description_filter: Filter
- description_search: Searchfield
- description_choose_project: Projects
- description_project_scope: Search scope
- description_notes: Notes
- description_message_content: Message content
- description_query_sort_criteria_attribute: Sort attribute
- description_query_sort_criteria_direction: Sort direction
- description_user_mail_notification: Mail notification settings
- description_available_columns: Available Columns
- description_selected_columns: Selected Columns
- description_all_columns: All Columns
- description_issue_category_reassign: Choose issue category
- description_wiki_subpages_reassign: Choose new parent page
- description_date_range_list: Choose range from list
- description_date_range_interval: Choose range by selecting start and end date
- description_date_from: Enter start date
- description_date_to: Enter end date
- text_repository_identifier_info: 'Only lower case letters (a-z), numbers, dashes and underscores are allowed.
Once saved, the identifier cannot be changed.'
-
- #modify by mkz
- #by young
- label_requirement: Calls
- label_requirement_focus: Calls # modified by bai
- label_developer: Users
- label_investor: Investor:
- label_theme: Theme
- label_logged_as_new: Current user
- button_register: Register
- issue_list: Issue list
- lastest_respond: Lastest reply
- label_news_lastest: Lastest news
- label_version_display_settings: Display settings
- label_versions_progress: Complete schedule
- label_versions_description: Versions description
- label_my_photo: My photo
- label_documents_sort: Order setting:
- label_activities_settings: Display settings
- #end
-
-
- #huang
- label_file_new: Download
- label_user_edit: "Edit information"
- label_user_info: "User information" #huang 添加
- label_user_watcher: "Following" # huang添加的 # modified by bai
- label_user_fans: "Followed by" # modified by bai
-
- # modify by men
- label_x_user_fans:
- zero: fan
- one: fan
- other: fans
- #end
- label_user_commits: "Code commits"
- label_user_watchered: "Followed by" # huang添加的
- label_user_newfeedback: "Messages" ## huang添加的 # modified by bai
- label_user_login: "Last login:"
- label_user_mail: "E-mail:"
- label_user_joinin: "Join date:"
- label_user_activities: "You have no activities,come and join us!"
- label_user_activities_other: The user has no activities now!
- label_project_overview: "Overview"
- label_project_tool: "Tool"
- label_project_issues: "Issues"
- label_project_newother: "See other comments"
- label_project_newshare: "has shared"
- label_project_newadd: "added"
- label_project_unadd: "No project,go to creat it!"
- label_project_un: "You haven't joined any project!"
- #end by huang
-
- #added by liuping
- button_unfollow: Unfollow
- button_follow: Follow
- label_delete_confirm: Confirm delete?
- label_more_tags: More
- label_tags_bid: Call name
- label_tags_bid_description: call description
- label_tags_issue_description: issue description
- label_tags_all_objects: all objects
-
- #fq
- button_leave_meassge: Submit
- label_leave_message_to: leave %{name} a message
- label_leave_message: Message content
- label_message: message board
- field_add: Add before %{time}
- button_more: More
- label_user_response: Feedbacks # modified by bai
- label_bidding_project: projects
- button_bidding: I will participate in it
- label_new_call: New call
- label_user_information: My informations
-
- #Customer added!Added by nie
- label_create_time: Created time
- label_current_contributors: current contributors
- #modify by men
- label_x_current_contributors:
- zero: current contributor
- one: current contributor
- other: current contributors
- #end
- label_lines_of_code: lines of code
- label_since_last_commits: since last commit
- label_users_on_trustie: User
- label_front: first page
- label_commit_on: commit times
- #modify by men
- label_x_commit_on:
- zero: commit time
- one: commit time
- other: commit times
- #end
- label_follow_people: following # modified by bai
- #modify by men
- label_x_follow_people:
- zero: follower
- one: follower
- other: followers
- #end
- label_member_since: joined
- label_contribute_to: Participates %{project_count} projects:
- #modify by men
- label_x_contribute_to:
- zero: Participates %{count} project:
- one: Participates %{count} project:
- other: Participates %{count} projects:
- #end
- label_total_commit: Totally %{total_commit} commits # modified by bai
- #modify by men
- label_x_total_commit:
- zero: Totally %{count} commit
- one: Totally %{count} commit
- other: Totally %{count} commits
- #end
- label_upload_profile: Upload avatar
- label_type_as: Type as
- label_status_as: Status as
- label_priority_as: Priority as
- label_member_list: Member list
- label_author_name: Posted by %{author_name}
- label_comments_count: (%{count} comments)
- label_post_on: posts on
- label_find_all_comments: view all comments
- label_updated_time_on: " Updated on %{value} "
- label_call_list: Calls list
-
- label_requirement_list: Requirement list
- label_x_biding_project: #modify by men
- zero: project
- one: project
- other: projects
- #end
- label_x_responses: #modify by men
- zero: comment
- one: comment
- other: comments
- #end
- label_x_followers: #modified by men
- zero: follower
- one: follower
- other: followers
- #end
-
-
-
- label_price: price:
- label_RMB_sign: ¥
- label_investment_budget: Investment budget:
- label_investment_time_limit: Investment time limit:
- label_my_respond: Feedbacks: # modified by bai
- label_respond_requirement: has commented this call
- label_deadline: deadline yyyy-mm-dd
- label_requirement_name: give your requirement a name ~~
- label_requirement_description: content:descript your requirement
- label_requirement_bargain_money: type in your rewards(ex. money, reward, grade)
- label_wrong_budget: The error format of money
- label_wrong_date: wrong date format, input right date yyyy-mm-dd
- button_upload_photo: Upload photo
- label_leave_me_message: left a message to me
- label_leave_others_message: leave message to him/her
- label_leave_a_message: Leave him/her a message:
- label_new_activities: ' has new activity in' # modified by bai
- label_new_activity: ' has new activity in'
- label_i_new_activity: ' have new activity in'
- label_create_project: had participated in
- label_praise: praise
- label_cancel_praise: cancel praise
- label_bid_reason: Please show your reason
- default_tracker_task: Task
- label_create_new_projects_description: Create a new project, you will open a magical journey of collaborative creation and development!
- label_call_for_bids_description: Publish your call for anything, feel the excitement of hundreds respond to a single call!
- label_create_course_description: Create a new course, let us share the public resources in the course community which are more than you can imagine!
- label_news: News
- label_news_description: Track the latest activities of projects, and obtain the latest information!
- label_milestone: Milestone
- label_milestone_description: Review the commits, branches and versions of your project!
- label_features: Features
- label_has_praisers: praisers(%{count})
- label_has_watchers: following(%{count}) # modified by bai
- label_has_fans: followed by(%{count}) # modified by bai
- #modify by men
- label_x_has_fans:
- zero: fan(%{count})
- one: fan(%{count})
- other: fans(%{count})
- #end
- label_me: me
- label_my: my
- label_i: I
- label_join_bidding: joined the bidding
- label_bidding_user: Bidding user:
- label_bidding_reason: Bidding reason:
- label_username: username:
- label_password: password:
- label_about_requirement: about requirement:
- label_about_issue: about issue:
- label_quote_my_words: ' quoted my words'
- label_have_respond: had a respond
- label_welcome: Welcome
-
- label_join: join Trustie!
- label_repository_new: link to existing SVN repository
- label_repository_path: path of repository
- label_repository_new_repos: create a new repository
- label_repository_no: have no repository?
- label_welcome_page_to: Participate %{project_count} projects!
- label_repository_path_not_null: repository path can't be null
- label_password_not_null: password can't be blank
- label_exist_repository_path: Define exist repository's path of URL and format must be file:///, http://, https://, svn://
- label_project_no_activity: The project has no activities now!
- label_follow_no_requirement: You don't have followed any requirements!
- label_no_user_respond_you: There is no respond for you!
- label_tags_issue: issue:
- label_tags_project_name: Project name:
- label_tags_project_description: Project description:
- label_tags_user_mail: User E-mail:
- label_tags_user_name: User Name:
- label_tags_numbers: Tag numbers:
- label_max_number: Must be at most 25 characters long.
- label_all_revisions: All revisions:
- label_repository_name: Repository name
- label_upassword_info: The password can be shared in the group
- label_how_commit_code: How to commit code:
- label_how_commit_code_chinese: Chinese
- label_welcome_leave_message: Hi!The platform is currently in beta version.If you have any comments and suggestions, please
- label_welcome_click_me: Click me
- label_issue_praise: Good question,praise!
- label_issue_tread: Poor question,tread!
- label_issue_praise_over: Praised over!
- label_issue_tread_over: Treaded over!
- label_issue_appraise_over: Appraised over!
- label_welcome_my_respond: Please leave your comments and suggestions here!
- label_no_current_fans: the user has no fans now
- label_no_current_watchers: the user hasn't watched others
- label_project_tool_response: Response
- label_tags_search_result: Search Results
- label_active_call: call
- label_tags_call: Calls
- label_user_extensions: Other information
- label_boy: Man
- label_girl: Woman
- field_gender: Gender
- field_birthday: Birthday
- field_brief_introduction: Info
- field_location: Location
- field_occupation: Position
- field_work_experience: Work experience(year)
- field_zip_code: Zip code
- label_reward: reward:
- label_credit: credit:
- label_choose_reward: choose reward
- label_money: money
- label_reward_1: others
- label_bids_credit: credit
- label_bids_credit_number: points
- field_budget: reward
- field_deadline: deadline
- label_tags_selected: Selected Tags
- label_tags_related: Related Tags
- button_project_tags_add: Add
- label_issue_query_condition: Query condition
- label_homework_source: Task
- label_issue_query: Query
- label_issue_cancel_query: Cancel query
- field_reward_type: The type of reward
- label_tags_no: no tags now!
- label_bid_publish: published
- label_bid_project: projects
- label_project_no_follow: The project hasn't been followed now!
- label_no_bid_project: has no participate project
- label_bids_reward_method: reward:
- label_bids_reward_what: input what for reward
- label_call_bonus: bonus
- label_bids_form_new_description: Publish a requirement,a competition or a course work.
- label_bids_new_money: input the award money,such as 500,2.5 etc.
- label_bids_new_credit: input the work corresponding course credits,such as 3,2.5 etc.
- label_bids_new_content: input the award content,such as certificate,things etc.
- label_user_login_tips: You havn't logged in,for leaving message please login first
- label_user_login_new: login
- label_project_sort: the way of sorting
- #modified by bai
- label_sort_by_time: sorted by time
- label_sort_by_active: sorted by active
- label_sort_by_influence: sorted by influence
- #end
- label_bids_published: published
- label_bids_published_ago: ago
- label_welcome_trustie: Trustie forge
- label_welcome_trustie_description: a socialized collaboration platform for project management, collaborative research, software development and software crowdsourcing for creative university students and entrepreneurs.
- label_user_project: Projects
- label_bid_respond_quote: Respond
- label_bid_if_agreement: If you like me, please press me #bai
- label_bid_respond_delete: Delete
- label_newfeedback_message: messages
- label_newfeedback_quote: Respond
- label_newfeedback_delete: Delete
- label_user_all_activity: All activities
- label_user_activity_myself: About me
- label_user_all_respond: All replies
- label_layouts_feedback: Messages
- label_welcome_participate: participates
- #modify by men
- label_x_welcome_participate:
- zero: participate
- one: participate
- other: participates
- #end
- label_welcome_participate_project: projects
- label_projects_feedback: responded to the project
- label_projects_feedback_respond: Respond
- label_projects_feedback_respond_success: Respond success
- button_projects_feedback_respond: Respond
- label_projects_feedback_respond_content: Please input your words
- label_in_issues: in the issue:
- label_in_bids: in the call:
- label_in_users: in the user:
- label_user_create_project: has created
-
-#added by bai
- label_identity: Identity
- label_teacher: Teacher
- label_student: Student
- label_other: Other
- label_gender: Gender
- label_gender_male: male
- label_gender_female: female
- label_location: Location
-#end
- label_course: Course
- label_course_new: New course
- label_public_info: If you don't choose public, only the project's members can see the project.
- label_course_student: Student
- label_homework: Task
- label_course_new_homework: New homework
- label_course_homework_list: Homework List
- label_course_homework_new: new homework
-
- label_x_course_data:
- zero: File
- one: File
- other: Files
- #add by men
- label_brief_introduction: Personality words
- label_technical_title: Title
- label_technicl_title_professor: Professor
- label_technicl_title_associate_professor: Associate professor
- label_technicl_title_lecturer: Lecturer
- label_technicl_title_teaching_assistant: Teaching assistant
- label_account_identity_teacher: Teacher
- label_account_identity_student: Student
- label_account_identity_developer: Developer
- label_account_identity_enterprise: Enterprise
- label_account_identity_choose: --Please choose your identity--
- label_enter_college: College Entrance
- lable_enter_enterprise: Enterprise Entrance
- label_homework_info: Status
- label_question_student: Feedback
- label_student_response: Feedback
- label_my_question: Please raise your questions here!
- label_teacher_homework: Teacher's name
- label_course_homework: Corresponding course
- label_limit_time: Deadline
- label_commit_homework: Submitted Task
- label_no_course_project: No submitted work!
- button_clear_requirement: Cancel
-#end
- label_x_bids_responses: #modify by huang
- zero: response
- one: response
- other: responses
- #end
- label_teaching_course: My Courses
- label_release_homework: Released Tasks
- label_term: Term
- label_spring: spring term
- label_summer: summer term
- label_autumn: autumn term
- label_winter: winter term
- text_command: The password is required when applying a course, and it will be released by the teacher of.
- label_enterprise_into: Enterprise Entrance
- label_college_into: College Entrance
- label_user_course: Courses
- label_new_course: Courses
- field_tea_name: Teacher
- label_course_college: College
- label_x_task:
- zero: Task
- one: Task
- other: Tasks
- label_project_course_unadd: You have no course,creat one now!
- label_my_create_honework_no_homework: no task now!
- label_my_homework_no_homework: no task now!
- label_x_member:
- zero: member
- one: member
- other: members
- label_x_data:
- zero: file
- one: file
- other: files
- label_bid_show_course_name: Course
- label_bid_show_teacher_name: Teacher
- label_bid_contest_show_course_name: Course
- label_bid_contest_show_teacher_name: Teacher
- label_x_homework_project:
- zero: submitted task
- one: submitted task
- other: submitted tasks
- label_new_homework: Tasks
- label_new_contest: Contests
- label_contest_list: Contests list
- label_newtype_contest: Release contest
- label_question_requirement: introduce a question!
- button_bidding_homework: To take part in contest
- label_bids_form_contest_new_description: Enterprise or college can release a contest here.
- label_contest_name: Input the name of the contest
- label_contest_description: Content:description your contest
- label_main_teacher: Main teacher
- label_main_term: Term
- label_teacher_work_unit: Position
- label_course_overview: Status
- label_course_file: File
- label_course_news: News
-
- label_x_base_courses_member:
- zero: member
- one: member
- other: members
-
- label_bids_task_list: Tasks list
- label_join_course: join course
- label_exit_course: exit course
- label_new_join: Join
- label_new_join_order: Please input the course order.
- label_homeworks_form_new_description: Release a task,the submit form of the task may be accessory or project,setting in the task form.
- label_course_settings: Setting
- field_homework_type: Submit form
- label_task_submit_form_accessory: Submitted as accessory
- label_task_submit_form_project: Submitted as project
- label_news_notice: Release course news
-
- role_of_course: Role
- label_student: student
- label_teacher: teacher
- label_ta: teacher assistant
- label_in_course: in course
- label_assign_homework: assigned homewok
- label_noawards: No awards
+en:
+ # Text direction: Left-to-Right (ltr) or Right-to-Left (rtl)
+ direction: ltr
+ date:
+ formats:
+ # Use the strftime parameters for formats.
+ # When no format has been given, it uses default.
+ # You can provide other formats here if you like!
+ default: "%m/%d/%Y"
+ short: "%b %d"
+ long: "%B %d, %Y"
+
+ day_names: [Sunday, Monday, Tuesday, Wednesday, Thursday, Friday, Saturday]
+ abbr_day_names: [Sun, Mon, Tue, Wed, Thu, Fri, Sat]
+
+ # Don't forget the nil at the beginning; there's no such thing as a 0th month
+ month_names: [~, January, February, March, April, May, June, July, August, September, October, November, December]
+ abbr_month_names: [~, Jan, Feb, Mar, Apr, May, Jun, Jul, Aug, Sep, Oct, Nov, Dec]
+ # Used in date_select and datime_select.
+ order:
+ - :year
+ - :month
+ - :day
+
+ time:
+ formats:
+ default: "%m/%d/%Y %I:%M %p"
+ time: "%I:%M %p"
+ short: "%d %b %H:%M"
+ long: "%B %d, %Y %H:%M"
+ am: "am"
+ pm: "pm"
+
+ datetime:
+ distance_in_words:
+ half_a_minute: "half a minute"
+ less_than_x_seconds:
+ one: "less than 1 second"
+ other: "less than %{count} seconds"
+ x_seconds:
+ one: "1 second"
+ other: "%{count} seconds"
+ less_than_x_minutes:
+ one: "less than a minute"
+ other: "less than %{count} minutes"
+ x_minutes:
+ one: "1 minute"
+ other: "%{count} minutes"
+ about_x_hours:
+ one: "about 1 hour"
+ other: "about %{count} hours"
+ x_hours:
+ one: "1 hour"
+ other: "%{count} hours"
+ x_days:
+ one: "1 day"
+ other: "%{count} days"
+ about_x_months:
+ one: "about 1 month"
+ other: "about %{count} months"
+ x_months:
+ one: "1 month"
+ other: "%{count} months"
+ about_x_years:
+ one: "about 1 year"
+ other: "about %{count} years"
+ over_x_years:
+ one: "over 1 year"
+ other: "over %{count} years"
+ almost_x_years:
+ one: "almost 1 year"
+ other: "almost %{count} years"
+
+ number:
+ format:
+ separator: "."
+ delimiter: ""
+ precision: 3
+
+ human:
+ format:
+ delimiter: ""
+ precision: 3
+ storage_units:
+ format: "%n %u"
+ units:
+ byte:
+ one: "Byte"
+ other: "Bytes"
+ kb: "KB"
+ mb: "MB"
+ gb: "GB"
+ tb: "TB"
+
+# Used in array.to_sentence.
+ support:
+ array:
+ sentence_connector: "and"
+ skip_last_comma: false
+
+ activerecord:
+ errors:
+ template:
+ header:
+ one: "1 error prohibited this %{model} from being saved"
+ other: "%{count} errors prohibited this %{model} from being saved"
+ messages:
+ inclusion: "is not included in the list"
+ exclusion: "is reserved"
+ invalid: "is invalid"
+ confirmation: "doesn't match confirmation"
+ accepted: "must be accepted"
+ empty: "can't be empty"
+ blank: "can't be blank"
+ too_long: "is too long (maximum is %{count} characters)"
+ too_short: "is too short (minimum is %{count} characters)"
+ wrong_length: "is the wrong length (should be %{count} characters)"
+ taken: "has already been taken"
+ not_a_number: "is not a number"
+ not_a_date: "is not a valid date"
+ greater_than: "must be greater than %{count}"
+ greater_than_or_equal_to: "must be greater than or equal to %{count}"
+ equal_to: "must be equal to %{count}"
+ less_than: "must be less than %{count}"
+ less_than_or_equal_to: "must be less than or equal to %{count}"
+ odd: "must be odd"
+ even: "must be even"
+ greater_than_start_date: "must be greater than start date"
+ not_same_project: "doesn't belong to the same project"
+ circular_dependency: "This relation would create a circular dependency"
+ cant_link_an_issue_with_a_descendant: "An issue cannot be linked to one of its subtasks"
+
+ actionview_instancetag_blank_option: Please select
+
+ general_text_No: 'No'
+ general_text_Yes: 'Yes'
+ general_text_no: 'no'
+ general_text_yes: 'yes'
+ general_lang_name: 'English'
+ general_csv_separator: ','
+ general_csv_decimal_separator: '.'
+ general_csv_encoding: ISO-8859-1
+ general_pdf_encoding: UTF-8
+ general_first_day_of_week: '7'
+
+ notice_account_updated: Account was successfully updated.
+ notice_account_invalid_creditentials: Invalid user or password
+ notice_account_password_updated: Password was successfully updated.
+ notice_account_wrong_password: Wrong password
+ notice_account_register_done: Account was successfully created. To activate your account, click on the link that was emailed to you.
+ notice_account_unknown_email: Unknown user.
+ notice_can_t_change_password: This account uses an external authentication source. Impossible to change the password.
+ notice_account_lost_email_sent: An email with instructions to choose a new password has been sent to you.
+ notice_account_activated: Your account has been activated. You can now log in.
+ notice_successful_create: Successful creation.
+ notice_successful_update: Successful update.
+ notice_successful_delete: Successful deletion.
+ notice_successful_connection: Successful connection.
+ notice_file_not_found: The page you were trying to access doesn't exist or has been removed.
+ notice_locking_conflict: Data has been updated by another user.
+ notice_not_authorized: You are not authorized to access this page.
+ notice_not_authorized_archived_project: The project you're trying to access has been archived.
+ notice_email_sent: "An email was sent to %{value}"
+ notice_email_error: "An error occurred while sending mail (%{value})"
+ notice_feeds_access_key_reseted: Your RSS access key was reset.
+ notice_api_access_key_reseted: Your API access key was reset.
+ notice_failed_to_save_issues: "Failed to save %{count} issue(s) on %{total} selected: %{ids}."
+ notice_failed_to_save_time_entries: "Failed to save %{count} time entrie(s) on %{total} selected: %{ids}."
+ notice_failed_to_save_members: "Failed to save member(s): %{errors}."
+ notice_no_issue_selected: "No issue is selected! Please, check the issues you want to edit."
+ notice_account_pending: "Your account was created and is now pending administrator approval."
+ notice_default_data_loaded: Default configuration successfully loaded.
+ notice_unable_delete_version: Unable to delete version.
+ notice_unable_delete_time_entry: Unable to delete time log entry.
+ notice_issue_done_ratios_updated: Issue done ratios updated.
+ notice_gantt_chart_truncated: "The chart was truncated because it exceeds the maximum number of items that can be displayed (%{max})"
+ notice_issue_successful_create: "Issue %{id} created."
+ notice_issue_update_conflict: "The issue has been updated by an other user while you were editing it."
+ notice_account_deleted: "Your account has been permanently deleted."
+ notice_user_successful_create: "User %{id} created."
+
+ error_can_t_load_default_data: "Default configuration could not be loaded: %{value}"
+ error_scm_not_found: "The entry or revision was not found in the repository."
+ error_scm_command_failed: "An error occurred when trying to access the repository: %{value}"
+ error_scm_annotate: "The entry does not exist or cannot be annotated."
+ error_scm_annotate_big_text_file: "The entry cannot be annotated, as it exceeds the maximum text file size."
+ error_issue_not_found_in_project: 'The issue was not found or does not belong to this project'
+ error_no_tracker_in_project: 'No tracker is associated to this project. Please check the Project settings.'
+ error_no_default_issue_status: 'No default issue status is defined. Please check your configuration (Go to "Administration -> Issue statuses").'
+ error_can_not_delete_custom_field: Unable to delete custom field
+ error_can_not_delete_tracker: "This tracker contains issues and cannot be deleted."
+ error_can_not_remove_role: "This role is in use and cannot be deleted."
+ error_can_not_reopen_issue_on_closed_version: 'An issue assigned to a closed version cannot be reopened'
+ error_can_not_archive_project: This project cannot be archived
+ error_issue_done_ratios_not_updated: "Issue done ratios not updated."
+ error_workflow_copy_source: 'Please select a source tracker or role'
+ error_workflow_copy_target: 'Please select target tracker(s) and role(s)'
+ error_unable_delete_issue_status: 'Unable to delete issue status'
+ error_unable_to_connect: "Unable to connect (%{value})"
+ error_attachment_too_big: "This file cannot be uploaded because it exceeds the maximum allowed file size (%{max_size})"
+ error_session_expired: "Your session has expired. Please login again."
+ warning_attachments_not_saved: "%{count} file(s) could not be saved."
+
+ mail_subject_lost_password: "Your %{value} password"
+ mail_body_lost_password: 'To change your password, click on the following link:'
+ mail_subject_register: "Your %{value} account activation"
+ mail_body_register: 'To activate your account, click on the following link:'
+ mail_body_account_information_external: "You can use your %{value} account to log in."
+ mail_body_account_information: Your account information
+ mail_subject_account_activation_request: "%{value} account activation request"
+ mail_body_account_activation_request: "A new user (%{value}) has registered. The account is pending your approval:"
+ mail_subject_reminder: "%{count} issue(s) due in the next %{days} days"
+ mail_body_reminder: "%{count} issue(s) that are assigned to you are due in the next %{days} days:"
+ mail_subject_wiki_content_added: "'%{id}' wiki page has been added"
+ mail_body_wiki_content_added: "The '%{id}' wiki page has been added by %{author}."
+ mail_subject_wiki_content_updated: "'%{id}' wiki page has been updated"
+ mail_body_wiki_content_updated: "The '%{id}' wiki page has been updated by %{author}."
+
+ field_name: Name
+ field_description: Description
+ field_summary: Summary
+ field_is_required: Required
+ field_firstname: First name
+ field_lastname: Last name
+ field_mail: Email
+ field_job_category: Job category # added by bai
+ field_filename: File
+ field_filesize: Size
+ field_downloads: Downloads
+ field_author: Author
+ field_created_on: Created
+ field_updated_on: Updated
+ field_closed_on: Closed
+ field_field_format: Format
+ field_is_for_all: For all projects
+ field_possible_values: Possible values
+ field_regexp: Regular expression
+ field_min_length: Minimum length
+ field_max_length: Maximum length
+ field_value: Value
+ field_category: Category
+ field_title: Title
+ field_project: Project
+ field_issue: Issue
+ field_status: Status
+ field_notes: Notes
+ field_is_closed: Issue closed
+ field_is_default: Default value
+ field_tracker: Tracker
+ field_subject: Subject
+ field_due_date: Due date
+ field_assigned_to: Assignee
+ field_priority: Priority
+ field_fixed_version: Target version
+ field_user: User
+ field_principal: Principal
+ field_role: Role
+ field_homepage: Homepage
+ field_is_public: Public
+ field_parent: Subproject of
+ field_is_in_roadmap: Issues displayed in roadmap
+ field_login: Login
+ field_mail_notification: Email notifications
+ field_admin: Administrator
+ field_last_login_on: Last connection
+ field_language: Language
+ field_effective_date: Date
+ field_password: Password
+ field_new_password: New password
+ field_password_confirmation: Confirmation
+ field_version: Version
+ field_type: Type
+ field_host: Host
+ field_port: Port
+ field_account: Account
+ field_base_dn: Base DN
+ field_attr_login: Login attribute
+ field_attr_firstname: Firstname attribute
+ field_attr_lastname: Lastname attribute
+ field_attr_mail: Email attribute
+ field_onthefly: On-the-fly user creation
+ field_start_date: Start date
+ field_done_ratio: "% Done"
+ field_auth_source: Authentication mode
+ field_hide_mail: Hide my email address
+ field_comments: Comment
+ field_url: URL
+ field_start_page: Start page
+ field_subproject: Subproject
+ field_hours: Hours
+ field_activity: Activity
+ field_spent_on: Date
+ field_identifier: Identifier
+ field_is_filter: Used as a filter
+ field_issue_to: Related issue
+ field_delay: Delay
+ field_assignable: Issues can be assigned to this role
+ field_redirect_existing_links: Redirect existing links
+ field_estimated_hours: Estimated time
+ field_column_names: Columns
+ field_time_entries: Log time
+ field_time_zone: Time zone
+ field_searchable: Searchable
+ field_default_value: Default value
+ field_comments_sorting: Display comments
+ field_parent_title: Parent page
+ field_editable: Editable
+ field_watcher: Watcher
+ field_identity_url: OpenID URL
+ field_content: Content
+ field_group_by: Group results by
+ field_sharing: Sharing
+ field_parent_issue: Parent task
+ field_member_of_group: "Assignee's group"
+ field_assigned_to_role: "Assignee's role"
+ field_text: Text field
+ field_visible: Visible
+ field_warn_on_leaving_unsaved: "Warn me when leaving a page with unsaved text"
+ field_issues_visibility: Issues visibility
+ field_is_private: Private
+ field_commit_logs_encoding: Commit messages encoding
+ field_scm_path_encoding: Path encoding
+ field_path_to_repository: Path to repository
+ field_root_directory: Root directory
+ field_cvsroot: CVSROOT
+ field_cvs_module: Module
+ field_repository_is_default: Main repository
+ field_multiple: Multiple values
+ field_auth_source_ldap_filter: LDAP filter
+ field_core_fields: Standard fields
+ field_timeout: "Timeout (in seconds)"
+ field_board_parent: Parent forum
+ field_private_notes: Private notes
+ field_inherit_members: Inherit members
+
+ setting_app_title: Application title
+ setting_app_subtitle: Application subtitle
+ setting_welcome_text: Welcome text
+ setting_default_language: Default language
+ setting_login_required: Authentication required
+ setting_self_registration: Self-registration
+ setting_attachment_max_size: Maximum attachment size
+ setting_issues_export_limit: Issues export limit
+ setting_mail_from: Emission email address
+ setting_bcc_recipients: Blind carbon copy recipients (bcc)
+ setting_plain_text_mail: Plain text mail (no HTML)
+ setting_host_name: Host name and path
+ setting_text_formatting: Text formatting
+ setting_wiki_compression: Wiki history compression
+ setting_feeds_limit: Maximum number of items in Atom feeds
+ setting_default_projects_public: New projects are public by default
+ setting_autofetch_changesets: Fetch commits automatically
+ setting_sys_api_enabled: Enable WS for repository management
+ setting_commit_ref_keywords: Referencing keywords
+ setting_commit_fix_keywords: Fixing keywords
+ setting_autologin: Autologin
+ setting_date_format: Date format
+ setting_time_format: Time format
+ setting_cross_project_issue_relations: Allow cross-project issue relations
+ setting_cross_project_subtasks: Allow cross-project subtasks
+ setting_issue_list_default_columns: Default columns displayed on the issue list
+ setting_repositories_encodings: Attachments and repositories encodings
+ setting_emails_header: Email header
+ setting_emails_footer: Email footer
+ setting_protocol: Protocol
+ setting_per_page_options: Objects per page options
+ setting_user_format: Users display format
+ setting_activity_days_default: Days displayed on project activity
+ setting_display_subprojects_issues: Display subprojects issues on main projects by default
+ setting_enabled_scm: Enabled SCM
+ setting_mail_handler_body_delimiters: "Truncate emails after one of these lines"
+ setting_mail_handler_api_enabled: Enable WS for incoming emails
+ setting_mail_handler_api_key: API key
+ setting_sequential_project_identifiers: Generate sequential project identifiers
+ setting_gravatar_enabled: Use Gravatar user icons
+ setting_gravatar_default: Default Gravatar image
+ setting_diff_max_lines_displayed: Maximum number of diff lines displayed
+ setting_file_max_size_displayed: Maximum size of text files displayed inline
+ setting_repository_log_display_limit: Maximum number of revisions displayed on file log
+ setting_openid: Allow OpenID login and registration
+ setting_password_min_length: Minimum password length
+ setting_new_project_user_role_id: Role given to a non-admin user who creates a project
+ setting_default_projects_modules: Default enabled modules for new projects
+ setting_issue_done_ratio: Calculate the issue done ratio with
+ setting_issue_done_ratio_issue_field: Use the issue field
+ setting_issue_done_ratio_issue_status: Use the issue status
+ setting_start_of_week: Start calendars on
+ setting_rest_api_enabled: Enable REST web service
+ setting_cache_formatted_text: Cache formatted text
+ setting_default_notification_option: Default notification option
+ setting_commit_logtime_enabled: Enable time logging
+ setting_commit_logtime_activity_id: Activity for logged time
+ setting_gantt_items_limit: Maximum number of items displayed on the gantt chart
+ setting_issue_group_assignment: Allow issue assignment to groups
+ setting_default_issue_start_date_to_creation_date: Use current date as start date for new issues
+ setting_commit_cross_project_ref: Allow issues of all the other projects to be referenced and fixed
+ setting_unsubscribe: Allow users to delete their own account
+ setting_session_lifetime: Session maximum lifetime
+ setting_session_timeout: Session inactivity timeout
+ setting_thumbnails_enabled: Display attachment thumbnails
+ setting_thumbnails_size: Thumbnails size (in pixels)
+ setting_non_working_week_days: Non-working days
+ setting_jsonp_enabled: Enable JSONP support
+ setting_default_projects_tracker_ids: Default trackers for new projects
+
+ permission_add_project: Create project
+ permission_add_subprojects: Create subprojects
+ permission_edit_project: Edit project
+ permission_close_project: Close / reopen the project
+ permission_select_project_modules: Select project modules
+ permission_manage_members: Manage members
+ permission_manage_project_activities: Manage project activities
+ permission_manage_versions: Manage versions
+ permission_manage_categories: Manage issue categories
+ permission_view_issues: View Issues
+ permission_add_issues: Add issues
+ permission_edit_issues: Edit issues
+ permission_manage_issue_relations: Manage issue relations
+ permission_set_issues_private: Set issues public or private
+ permission_set_own_issues_private: Set own issues public or private
+ permission_add_issue_notes: Add notes
+ permission_edit_issue_notes: Edit notes
+ permission_edit_own_issue_notes: Edit own notes
+ permission_view_private_notes: View private notes
+ permission_set_notes_private: Set notes as private
+ permission_move_issues: Move issues
+ permission_delete_issues: Delete issues
+ permission_manage_public_queries: Manage public queries
+ permission_save_queries: Save queries
+ permission_view_gantt: View gantt chart
+ permission_view_calendar: View calendar
+ permission_view_issue_watchers: View watchers list
+ permission_add_issue_watchers: Add watchers
+ permission_delete_issue_watchers: Delete watchers
+ permission_log_time: Log spent time
+ permission_view_time_entries: View spent time
+ permission_edit_time_entries: Edit time logs
+ permission_edit_own_time_entries: Edit own time logs
+ permission_manage_news: Manage news
+ permission_comment_news: Comment news
+ permission_view_documents: View documents
+ permission_add_documents: Add documents
+ permission_edit_documents: Edit documents
+ permission_delete_documents: Delete documents
+ permission_manage_files: Manage files
+ permission_view_files: View files
+ permission_manage_wiki: Manage wiki
+ permission_rename_wiki_pages: Rename wiki pages
+ permission_delete_wiki_pages: Delete wiki pages
+ permission_view_wiki_pages: View wiki
+ permission_view_wiki_edits: View wiki history
+ permission_edit_wiki_pages: Edit wiki pages
+ permission_delete_wiki_pages_attachments: Delete attachments
+ permission_protect_wiki_pages: Protect wiki pages
+ permission_manage_repository: Manage repository
+ permission_browse_repository: Browse repository
+ permission_view_changesets: View changesets
+ permission_commit_access: Commit access
+ permission_manage_boards: Manage forums
+ permission_view_messages: View messages
+ permission_add_messages: Post messages
+ permission_edit_messages: Edit messages
+ permission_edit_own_messages: Edit own messages
+ permission_delete_messages: Delete messages
+ permission_delete_own_messages: Delete own messages
+ permission_export_wiki_pages: Export wiki pages
+ permission_manage_subtasks: Manage subtasks
+ permission_manage_related_issues: Manage related issues
+
+ project_module_issue_tracking: Issue tracking
+ project_module_time_tracking: Time tracking
+ project_module_news: News
+ project_module_documents: Documents
+ project_module_files: Files
+ project_module_wiki: Wiki
+ project_module_repository: Repository
+ project_module_boards: Forums
+ project_module_calendar: Calendar
+ project_module_gantt: Gantt
+
+ label_user: User
+ label_user_plural: Users
+ label_user_new: New user
+ label_user_anonymous: Anonymous
+ label_project: Project
+ label_activity_project: 'Project: ' #added by bai
+ label_project_new: New project
+ label_project_plural: Projects
+ label_x_projects:
+ zero: no projects
+ one: 1 project
+ other: "%{count} projects"
+ label_project_all: All Projects
+ label_project_latest: Latest projects
+ label_issue: Issue
+ label_issue_new: New issue
+ label_issue_plural: Issues
+ label_issue_view_all: View all issues
+ label_issues_by: "Issues by %{value}"
+ label_issue_added: Issue added
+ label_issue_updated: Issue updated
+ label_issue_note_added: Note added
+ label_issue_status_updated: Status updated
+ label_issue_priority_updated: Priority updated
+ label_document: Document
+ label_document_new: New document
+ label_document_plural: Documents
+ label_document_added: Document added
+ label_role: Role
+ label_role_plural: Roles
+ label_role_new: New role
+ label_role_and_permissions: Roles and permissions
+ label_role_anonymous: Anonymous
+ label_role_non_member: Non member
+ label_member: Members
+ label_member_new: New member
+ label_member_plural: Members
+ label_tracker: Tracker
+ label_tracker_plural: Trackers
+ label_tracker_new: New tracker
+ label_workflow: Workflow
+ label_issue_status: Issue status
+ label_issue_status_plural: Issue statuses
+ label_issue_status_new: New status
+ label_issue_category: Issue category
+ label_issue_category_plural: Issue categories
+ label_issue_category_new: New category
+ label_custom_field: Custom field
+ label_custom_field_plural: Custom fields
+ label_custom_field_new: New custom field
+ label_enumerations: Enumerations
+ label_enumeration_new: New value
+ label_information: Information
+ label_information_plural: Information
+ label_please_login: Please log in
+ label_register: Sign up
+ label_login_with_open_id_option: or login with OpenID
+ label_password_lost: Lost password
+ label_home: Home
+ label_my_page: My page
+ label_my_account: My account
+ label_my_projects: My projects
+ label_my_page_block: My page block
+ label_administration: Administration
+ label_login: Login
+ label_logout: Sign out
+ label_help: Help
+ label_reported_issues: Reported issues
+ label_assigned_to_me_issues: Issues assigned to me
+ label_last_login: Last connection
+ label_registered_on: Registered on
+ label_activity: Activities
+ label_overall_activity: Overall activity
+ label_user_activity: "%{value}'s activity"
+ label_new: New
+ label_new_user: registered a new account
+ label_logged_as: Logged in as
+ label_environment: Environment
+ label_authentication: Authentication
+ label_auth_source: Authentication mode
+ label_auth_source_new: New authentication mode
+ label_auth_source_plural: Authentication modes
+ label_subproject_plural: Subprojects
+ label_subproject_new: New subproject
+ label_and_its_subprojects: "%{value} and its subprojects"
+ label_min_max_length: Min - Max length
+ label_list: List
+ label_date: Date
+ label_integer: Integer
+ label_float: Float
+ label_boolean: Boolean
+ label_string: Text
+ label_text: Long text
+ label_attribute: Attribute
+ label_attribute_plural: Attributes
+ label_no_data: No data to display
+ label_change_status: Change status
+ label_history: History
+ label_attachment: Files
+ label_attachment_new: New file
+ label_attachment_delete: Delete file
+ label_attachment_plural: Files
+ label_file_added: File added
+ label_report: Report
+ label_report_plural: Reports
+ label_news: News
+ label_news_new: Add news
+ label_news_plural: News
+ label_news_latest: Latest news
+ label_news_view_all: View all news
+ label_news_added: News added
+ label_news_comment_added: Comment added to a news
+ label_settings: Settings
+ label_overview: Activities
+ label_version: Version
+ label_version_new: New version
+ label_version_plural: Versions
+ label_close_versions: Close completed versions
+ label_confirmation: Confirmation
+ label_export_to: 'Also available in:'
+ label_read: Read...
+ label_public_projects: Public projects
+ label_open_issues: open
+ label_open_issues_plural: open
+ label_closed_issues: closed
+ label_closed_issues_plural: closed
+ label_x_open_issues_abbr_on_total:
+ zero: 0 open / %{total}
+ one: 1 open / %{total}
+ other: "%{count} open / %{total}"
+ label_x_open_issues_abbr:
+ zero: 0 open
+ one: 1 open
+ other: "%{count} open"
+ label_x_closed_issues_abbr:
+ zero: 0 closed
+ one: 1 closed
+ other: "%{count} closed"
+ label_x_issues:
+ zero: 0 issues
+ one: 1 issue
+ other: "%{count} issues"
+ label_total: Total
+ label_total_time: Total time
+ label_permissions: Permissions
+ label_current_status: Current status
+ label_new_statuses_allowed: New statuses allowed
+ label_all: all
+ label_any: any
+ label_none: none
+ label_nobody: nobody
+ label_next: Next
+ label_previous: Previous
+ label_used_by: Used by
+ label_details: Details
+ label_add_note: Add a note
+ label_per_page: Per page
+ label_calendar: Calendar
+ label_months_from: months from
+ label_gantt: Gantt
+ label_internal: Internal
+ label_last_changes: "last %{count} changes"
+ label_change_view_all: View all changes
+ label_personalize_page: Personalize this page
+ label_comment: Comment
+ label_comment_plural: Comments
+ label_x_comments:
+ zero: no comments
+ one: 1 comment
+ other: "%{count} comments"
+ label_comment_add: Add a comment
+ label_comment_added: Comment added
+ label_comment_delete: Delete comments
+ label_query: Custom query
+ label_query_plural: Custom queries
+ label_query_new: New query
+ label_my_queries: My custom queries
+ label_filter_add: Add filter
+ label_filter_plural: Query condition
+ label_equals: is
+ label_not_equals: is not
+ label_in_less_than: in less than
+ label_in_more_than: in more than
+ label_in_the_next_days: in the next
+ label_in_the_past_days: in the past
+ label_in_users: 'in the user '
+ label_greater_or_equal: '>='
+ label_less_or_equal: '<='
+ label_between: between
+ label_in: in
+ label_today: today
+ label_all_time: all time
+ label_yesterday: yesterday
+ label_this_week: this week
+ label_last_week: last week
+ label_last_n_weeks: "last %{count} weeks"
+ label_last_n_days: "last %{count} days"
+ label_this_month: this month
+ label_last_month: last month
+ label_this_year: this year
+ label_date_range: Date range
+ label_less_than_ago: less than days ago
+ label_more_than_ago: more than days ago
+ label_ago: days ago
+ label_contains: contains
+ label_not_contains: doesn't contain
+ label_any_issues_in_project: any issues in project
+ label_any_issues_not_in_project: any issues not in project
+ label_no_issues_in_project: no issues in project
+ label_day_plural: days
+ label_repository: Repository
+ #add by tan
+ label_repository_new: Repository setting
+ label_repository_no: Have no repository?
+ label_repository_new_repos: New repository
+ #end
+ label_repository_plural: Repositories
+ label_browse: Browse
+ label_branch: Branch
+ label_tag: Tag
+ label_revision: Revision
+ label_revision_plural: Revisions
+ label_revision_id: "Revision %{value}"
+ label_associated_revisions: Associated revisions
+ label_added: added
+ label_modified: modified
+ label_copied: copied
+ label_renamed: renamed
+ label_deleted: deleted
+ label_latest_revision: Latest revision
+ label_latest_revision_plural: Latest revisions
+ label_view_revisions: View revisions
+ label_view_all_revisions: View all revisions
+ label_max_size: Maximum size
+ label_sort_highest: Move to top
+ label_sort_higher: Move up
+ label_sort_lower: Move down
+ label_sort_lowest: Move to bottom
+ label_roadmap: Roadmap
+ label_roadmap_due_in: "Due in %{value}"
+ label_roadmap_overdue: "%{value} late"
+ label_roadmap_no_issues: No issues for this version
+ label_search: Search
+ label_result_plural: Results
+ label_all_words: All words
+ label_wiki: Wiki
+ label_wiki_edit: Wiki edit
+ label_wiki_edit_plural: Wiki edits
+ label_wiki_page: Wiki page
+ label_wiki_page_plural: Wiki pages
+ label_index_by_title: Index by title
+ label_index_by_date: Index by date
+ label_current_version: Current version
+ label_preview: Preview
+ label_feed_plural: Feeds
+ label_changes_details: Details of all changes
+ label_issue_tracking: Issue tracking
+ label_spent_time: Spent time
+ label_overall_spent_time: Overall spent time
+ label_f_hour: "%{value} hour"
+ label_f_hour_plural: "%{value} hours"
+ label_time_tracking: Time tracking
+ label_change_plural: Changes
+ label_statistics: Statistics
+ label_commits_per_month: Commits per month
+ label_commits_per_author: Commits per author
+ label_diff: diff
+ label_view_diff: View differences
+ label_diff_inline: inline
+ label_diff_side_by_side: side by side
+ label_options: Options
+ label_copy_workflow_from: Copy workflow from
+ label_permissions_report: Permissions report
+ label_watched_issues: Watched issues
+ label_related_issues: Related issues
+ label_applied_status: Applied status
+ label_loading: Loading...
+ label_relation_new: New relation
+ label_relation_delete: Delete relation
+ label_relates_to: Related to
+ label_duplicates: Duplicates
+ label_duplicated_by: Duplicated by
+ label_blocks: Blocks
+ label_blocked_by: Blocked by
+ label_precedes: Precedes
+ label_follows: Follows
+ label_copied_to: Copied to
+ label_copied_from: Copied from
+ label_end_to_start: end to start
+ label_end_to_end: end to end
+ label_start_to_start: start to start
+ label_start_to_end: start to end
+ label_stay_logged_in: Stay logged in
+ label_disabled: disabled
+ label_show_completed_versions: Show completed versions
+ label_me: me
+ label_board: Forums
+ label_board_description: Bring together the wisdom of crowds, and solve problems for you!
+ label_board_new: New forum
+ label_board_plural: Forums
+ label_board_locked: Locked
+ label_board_sticky: Sticky
+ label_topic_plural: Topics
+ label_message_plural: Messages
+ label_message_last: Last message
+ label_message_new: New message
+ label_message_posted: Message added
+ label_reply_plural: Replies
+ label_send_information: Send account information to the user
+ label_year: Year
+ label_month: Month
+ label_week: Week
+ label_date_from: From
+ label_date_to: To
+ label_language_based: Based on user's language
+ label_sort_by: "Sort by %{value}"
+ label_send_test_email: Send a test email
+ label_feeds_access_key: RSS access key
+ label_missing_feeds_access_key: Missing a RSS access key
+ label_feeds_access_key_created_on: "RSS access key created %{value} ago"
+ label_module_plural: Modules
+ label_added_time_by: "Added by %{author} %{age} ago"
+ label_updated_time_by: "Updated by %{author} %{age} ago"
+ label_updated_time: "Updated %{value} ago"
+ label_jump_to_a_project: Jump to a project...
+ label_file_plural: Files
+ label_changeset_plural: Changesets
+ label_default_columns: Default columns
+ label_no_change_option: (No change)
+ label_bulk_edit_selected_issues: Bulk edit selected issues
+ label_bulk_edit_selected_time_entries: Bulk edit selected time entries
+ label_theme: Theme
+ label_default: Default
+ label_search_titles_only: Search titles only
+ label_user_mail_option_all: "For any event on all my projects"
+ label_user_mail_option_selected: "For any event on the selected projects only..."
+ label_user_mail_option_none: "No events"
+ label_user_mail_option_only_my_events: "Only for things I watch or I'm involved in"
+ label_user_mail_option_only_assigned: "Only for things I am assigned to"
+ label_user_mail_option_only_owner: "Only for things I am the owner of"
+ label_user_mail_no_self_notified: "I don't want to be notified of changes that I make myself"
+ label_registration_activation_by_email: account activation by email
+ label_registration_manual_activation: manual account activation
+ label_registration_automatic_activation: automatic account activation
+ label_display_per_page: "Per page: %{value}"
+ label_age: Age
+ label_change_properties: Change properties
+ label_general: General
+ label_more: More
+ label_scm: SCM
+ label_plugins: Plugins
+ label_ldap_authentication: LDAP authentication
+ label_downloads_abbr: D/L
+ label_optional_description: Optional description
+ label_add_another_file: Add another file
+ label_preferences: Preferences
+ label_chronological_order: In chronological order
+ label_reverse_chronological_order: In reverse chronological order
+ label_planning: Planning
+ label_incoming_emails: Incoming emails
+ label_generate_key: Generate a key
+ label_issue_watchers: Watchers
+ label_example: Example
+ label_display: Display
+ label_sort: Sort
+ label_ascending: Ascending
+ label_descending: Descending
+ label_date_from_to: From %{start} to %{end}
+ label_wiki_content_added: Wiki page added
+ label_wiki_content_updated: Wiki page updated
+ label_group: Group
+ label_group_plural: Groups
+ label_group_new: New group
+ label_time_entry_plural: Spent time
+ label_version_sharing_none: Not shared
+ label_version_sharing_descendants: With subprojects
+ label_version_sharing_hierarchy: With project hierarchy
+ label_version_sharing_tree: With project tree
+ label_version_sharing_system: With all projects
+ label_update_issue_done_ratios: Update issue done ratios
+ label_copy_source: Source
+ label_copy_target: Target
+ label_copy_same_as_target: Same as target
+ label_display_used_statuses_only: Only display statuses that are used by this tracker
+ label_api_access_key: API access key
+ label_missing_api_access_key: Missing an API access key
+ label_api_access_key_created_on: "API access key created %{value} ago"
+ label_profile: Profile
+ label_subtask_plural: Subtasks
+ label_project_copy_notifications: Send email notifications during the project copy
+ label_principal_search: "Search for user or group:"
+ label_user_search: "Search for user:"
+ label_additional_workflow_transitions_for_author: Additional transitions allowed when the user is the author
+ label_additional_workflow_transitions_for_assignee: Additional transitions allowed when the user is the assignee
+ label_issues_visibility_all: All issues
+ label_issues_visibility_public: All non private issues
+ label_issues_visibility_own: Issues created by or assigned to the user
+ label_git_report_last_commit: Report last commit for files and directories
+ label_parent_revision: Parent
+ label_child_revision: Child
+ label_export_options: "%{export_format} export options"
+ label_copy_attachments: Copy attachments
+ label_copy_subtasks: Copy subtasks
+ label_item_position: "%{position} of %{count}"
+ label_completed_versions: Completed versions
+ label_search_for_watchers: Search for watchers to add
+ label_session_expiration: Session expiration
+ label_show_closed_projects: View closed projects
+ label_status_transitions: Status transitions
+ label_fields_permissions: Fields permissions
+ label_readonly: Read-only
+ label_required: Required
+ label_attribute_of_project: "Project's %{name}"
+ label_attribute_of_issue: "Issue's %{name}"
+ label_attribute_of_author: "Author's %{name}"
+ label_attribute_of_assigned_to: "Assignee's %{name}"
+ label_attribute_of_user: "User's %{name}"
+ label_attribute_of_fixed_version: "Target version's %{name}"
+ label_cross_project_descendants: With subprojects
+ label_cross_project_tree: With project tree
+ label_cross_project_hierarchy: With project hierarchy
+ label_cross_project_system: With all projects
+ label_gantt_progress_line: Progress line
+
+ button_login: Login
+ button_submit: Submit
+ button_save: Save
+ button_check_all: Check all
+ button_uncheck_all: Uncheck all
+ button_collapse_all: Collapse all
+ button_expand_all: Expand all
+ button_delete: Delete
+ button_create: Create
+ button_create_and_continue: Create and continue
+ button_test: Test
+ button_edit: Edit
+ button_edit_associated_wikipage: "Edit associated Wiki page: %{page_title}"
+ button_add: Add
+ button_change: Change
+ button_apply: Query
+ button_clear: Cancel query
+ button_lock: Lock
+ button_unlock: Unlock
+ button_download: Download
+ button_list: List
+ button_view: View
+ button_move: Move
+ button_move_and_follow: Move and follow
+ button_back: Back
+ button_cancel: Cancel
+ button_activate: Activate
+ button_sort: Sort
+ button_log_time: Log time
+ button_rollback: Rollback to this version
+ button_watch: Watch
+ button_unwatch: Unwatch
+ button_reply: Reply
+ button_archive: Archive
+ button_unarchive: Unarchive
+ button_reset: Reset
+ button_rename: Rename
+ button_change_password: Change password
+ button_copy: Copy
+ button_copy_and_follow: Copy and follow
+ button_annotate: Annotate
+ button_update: Update
+ button_configure: Configure
+ button_quote: Quote
+ button_duplicate: Duplicate
+ button_show: Show
+ button_hide: Hide
+ button_edit_section: Edit this section
+ button_export: Export
+ button_delete_my_account: Delete my account
+ button_close: Close
+ button_reopen: Reopen
+
+ status_active: active
+ status_registered: registered
+ status_locked: locked
+
+ project_status_active: active
+ project_status_closed: closed
+ project_status_archived: archived
+
+ version_status_open: open
+ version_status_locked: locked
+ version_status_closed: closed
+
+ field_active: Active
+
+ text_select_mail_notifications: Select actions for which email notifications should be sent.
+ text_regexp_info: eg. ^[A-Z0-9]+$
+ text_min_max_length_info: 0 means no restriction
+ text_project_destroy_confirmation: Are you sure you want to delete this project and related data?
+ text_subprojects_destroy_warning: "Its subproject(s): %{value} will be also deleted."
+ text_workflow_edit: Select a role and a tracker to edit the workflow
+ text_are_you_sure: Are you sure?
+ text_journal_changed: "%{label} changed from %{old} to %{new}"
+ text_journal_changed_no_detail: "%{label} updated"
+ text_journal_set_to: "%{label} set to %{value}"
+ text_journal_deleted: "%{label} deleted (%{old})"
+ text_journal_added: "%{label} %{value} added"
+ text_tip_issue_begin_day: issue beginning this day
+ text_tip_issue_end_day: issue ending this day
+ text_tip_issue_begin_end_day: issue beginning and ending this day
+ text_project_identifier_info: 'Only lower case letters (a-z), numbers, dashes and underscores are allowed, must start with a lower case letter.
Once saved, the identifier cannot be changed.'
+ text_caracters_maximum: "%{count} characters maximum."
+ text_caracters_minimum: "Must be at least %{count} characters long."
+ text_length_between: "Length between %{min} and %{max} characters."
+ text_tracker_no_workflow: No workflow defined for this tracker
+ text_unallowed_characters: Unallowed characters
+ text_comma_separated: Multiple values allowed (comma separated).
+ text_line_separated: Multiple values allowed (one line for each value).
+ text_issues_ref_in_commit_messages: Referencing and fixing issues in commit messages
+ text_issue_added: "Issue %{id} has been reported by %{author}."
+ text_issue_updated: "Issue %{id} has been updated by %{author}."
+ text_wiki_destroy_confirmation: Are you sure you want to delete this wiki and all its content?
+ text_issue_category_destroy_question: "Some issues (%{count}) are assigned to this category. What do you want to do?"
+ text_issue_category_destroy_assignments: Remove category assignments
+ text_issue_category_reassign_to: Reassign issues to this category
+ text_user_mail_option: "For unselected projects, you will only receive notifications about things you watch or you're involved in (eg. issues you're the author or assignee)."
+ text_no_configuration_data: "Roles, trackers, issue statuses and workflow have not been configured yet.\nIt is highly recommended to load the default configuration. You will be able to modify it once loaded."
+ text_load_default_configuration: Load the default configuration
+ text_status_changed_by_changeset: "Applied in changeset %{value}."
+ text_time_logged_by_changeset: "Applied in changeset %{value}."
+ text_issues_destroy_confirmation: 'Are you sure you want to delete the selected issue(s)?'
+ text_issues_destroy_descendants_confirmation: "This will also delete %{count} subtask(s)."
+ text_time_entries_destroy_confirmation: 'Are you sure you want to delete the selected time entr(y/ies)?'
+ text_select_project_modules: 'Select modules to enable for this project:'
+ text_default_administrator_account_changed: Default administrator account changed
+ text_file_repository_writable: Attachments directory writable
+ text_plugin_assets_writable: Plugin assets directory writable
+ text_rmagick_available: RMagick available (optional)
+ text_destroy_time_entries_question: "%{hours} hours were reported on the issues you are about to delete. What do you want to do?"
+ text_destroy_time_entries: Delete reported hours
+ text_assign_time_entries_to_project: Assign reported hours to the project
+ text_reassign_time_entries: 'Reassign reported hours to this issue:'
+ text_user_wrote: "%{value} wrote:"
+ text_enumeration_destroy_question: "%{count} objects are assigned to this value."
+ text_enumeration_category_reassign_to: 'Reassign them to this value:'
+ text_email_delivery_not_configured: "Email delivery is not configured, and notifications are disabled.\nConfigure your SMTP server in config/configuration.yml and restart the application to enable them."
+ text_repository_usernames_mapping: "Select or update the Redmine user mapped to each username found in the repository log.\nUsers with the same Redmine and repository username or email are automatically mapped."
+ text_diff_truncated: '... This diff was truncated because it exceeds the maximum size that can be displayed.'
+ text_custom_field_possible_values_info: 'One line for each value'
+ text_wiki_page_destroy_question: "This page has %{descendants} child page(s) and descendant(s). What do you want to do?"
+ text_wiki_page_nullify_children: "Keep child pages as root pages"
+ text_wiki_page_destroy_children: "Delete child pages and all their descendants"
+ text_wiki_page_reassign_children: "Reassign child pages to this parent page"
+ text_own_membership_delete_confirmation: "You are about to remove some or all of your permissions and may no longer be able to edit this project after that.\nAre you sure you want to continue?"
+ text_zoom_in: Zoom in
+ text_zoom_out: Zoom out
+ text_warn_on_leaving_unsaved: "The current page contains unsaved text that will be lost if you leave this page."
+ text_scm_path_encoding_note: "Default: UTF-8"
+ text_git_repository_note: Repository is bare and local (e.g. /gitrepo, c:\gitrepo)
+ text_mercurial_repository_note: Local repository (e.g. /hgrepo, c:\hgrepo)
+ text_scm_command: Command
+ text_scm_command_version: Version
+ text_scm_config: You can configure your SCM commands in config/configuration.yml. Please restart the application after editing it.
+ text_scm_command_not_available: SCM command is not available. Please check settings on the administration panel.
+ text_issue_conflict_resolution_overwrite: "Apply my changes anyway (previous notes will be kept but some changes may be overwritten)"
+ text_issue_conflict_resolution_add_notes: "Add my notes and discard my other changes"
+ text_issue_conflict_resolution_cancel: "Discard all my changes and redisplay %{link}"
+ text_account_destroy_confirmation: "Are you sure you want to proceed?\nYour account will be permanently deleted, with no way to reactivate it."
+ text_session_expiration_settings: "Warning: changing these settings may expire the current sessions including yours."
+ text_project_closed: This project is closed and read-only.
+ text_turning_multiple_off: "If you disable multiple values, multiple values will be removed in order to preserve only one value per item."
+
+ default_role_manager: Manager
+ default_role_developer: Developer
+ default_role_reporter: Reporter
+ default_tracker_bug: Bug
+ default_tracker_feature: Feature
+ default_tracker_support: Support
+ default_issue_status_new: New
+ default_issue_status_in_progress: In Progress
+ default_issue_status_resolved: Resolved
+ default_issue_status_feedback: Feedback
+ default_issue_status_closed: Closed
+ default_issue_status_rejected: Rejected
+ default_doc_category_user: User documentation
+ default_doc_category_tech: Technical documentation
+ default_priority_low: Low
+ default_priority_normal: Normal
+ default_priority_high: High
+ default_priority_urgent: Urgent
+ default_priority_immediate: Immediate
+ default_activity_design: Design
+ default_activity_development: Development
+
+ enumeration_issue_priorities: Issue priorities
+ enumeration_doc_categories: Document categories
+ enumeration_activities: Activities
+ enumeration_system_activity: System Activity
+ description_filter: Filter
+ description_search: Searchfield
+ description_choose_project: Projects
+ description_project_scope: Search scope
+ description_notes: Notes
+ description_message_content: Message content
+ description_query_sort_criteria_attribute: Sort attribute
+ description_query_sort_criteria_direction: Sort direction
+ description_user_mail_notification: Mail notification settings
+ description_available_columns: Available Columns
+ description_selected_columns: Selected Columns
+ description_all_columns: All Columns
+ description_issue_category_reassign: Choose issue category
+ description_wiki_subpages_reassign: Choose new parent page
+ description_date_range_list: Choose range from list
+ description_date_range_interval: Choose range by selecting start and end date
+ description_date_from: Enter start date
+ description_date_to: Enter end date
+ text_repository_identifier_info: 'Only lower case letters (a-z), numbers, dashes and underscores are allowed.
Once saved, the identifier cannot be changed.'
+
+ #modify by mkz
+ #by young
+ label_requirement: Calls
+ label_requirement_focus: Calls # modified by bai
+ label_developer: Users
+ label_investor: Investor:
+ label_theme: Theme
+ label_logged_as_new: Current user
+ button_register: Register
+ issue_list: Issue list
+ lastest_respond: Lastest reply
+ label_news_lastest: Lastest news
+ label_version_display_settings: Display settings
+ label_versions_progress: Complete schedule
+ label_versions_description: Versions description
+ label_my_photo: My photo
+ label_documents_sort: Order setting:
+ label_activities_settings: Display settings
+ #end
+
+
+ #huang
+ label_file_new: Download
+ label_user_edit: "Edit information"
+ label_user_info: "User information" #huang 添加
+ label_user_watcher: "Following" # huang添加的 # modified by bai
+ label_user_fans: "Followed by" # modified by bai
+
+ # modify by men
+ label_x_user_fans:
+ zero: fan
+ one: fan
+ other: fans
+ #end
+ label_user_commits: "Code commits"
+ label_user_watchered: "Followed by" # huang添加的
+ label_user_newfeedback: "Messages" ## huang添加的 # modified by bai
+ label_user_login: "Last login:"
+ label_user_mail: "E-mail:"
+ label_user_joinin: "Join date:"
+ label_user_activities: "You have no activities,come and join us!"
+ label_user_activities_other: The user has no activities now!
+ label_project_overview: "Overview"
+ label_project_tool: "Tool"
+ label_project_issues: "Issues"
+ label_project_newother: "See other comments"
+ label_project_newshare: "has shared"
+ label_project_newadd: "added"
+ label_project_unadd: "No project,go to creat it!"
+ label_project_un: "You haven't joined any project!"
+ #end by huang
+
+ #added by liuping
+ button_unfollow: Unfollow
+ button_follow: Follow
+ label_delete_confirm: Confirm delete?
+ label_more_tags: More
+ label_tags_bid: Call name
+ label_tags_bid_description: call description
+ label_tags_issue_description: issue description
+ label_tags_all_objects: all objects
+
+ #fq
+ button_leave_meassge: Submit
+ label_leave_message_to: leave %{name} a message
+ label_leave_message: Message content
+ label_message: message board
+ field_add: Add before %{time}
+ button_more: More
+ label_user_response: Feedbacks # modified by bai
+ label_bidding_project: projects
+ button_bidding: I will participate in it
+ label_new_call: New call
+ label_user_information: My informations
+
+ #Customer added!Added by nie
+ label_create_time: Created time
+ label_current_contributors: current contributors
+ #modify by men
+ label_x_current_contributors:
+ zero: current contributor
+ one: current contributor
+ other: current contributors
+ #end
+ label_lines_of_code: lines of code
+ label_since_last_commits: since last commit
+ label_users_on_trustie: User
+ label_front: first page
+ label_commit_on: commit times
+ #modify by men
+ label_x_commit_on:
+ zero: commit time
+ one: commit time
+ other: commit times
+ #end
+ label_follow_people: following # modified by bai
+ #modify by men
+ label_x_follow_people:
+ zero: follower
+ one: follower
+ other: followers
+ #end
+ label_member_since: joined
+ label_contribute_to: Participates %{project_count} projects:
+ #modify by men
+ label_x_contribute_to:
+ zero: Participates %{count} project:
+ one: Participates %{count} project:
+ other: Participates %{count} projects:
+ #end
+ label_total_commit: Totally %{total_commit} commits # modified by bai
+ #modify by men
+ label_x_total_commit:
+ zero: Totally %{count} commit
+ one: Totally %{count} commit
+ other: Totally %{count} commits
+ #end
+ label_upload_profile: Upload avatar
+ label_type_as: Type as
+ label_status_as: Status as
+ label_priority_as: Priority as
+ label_member_list: Member list
+ label_author_name: Posted by %{author_name}
+ label_comments_count: (%{count} comments)
+ label_post_on: posts on
+ label_find_all_comments: view all comments
+ label_updated_time_on: " Updated on %{value} "
+ label_call_list: Calls list
+
+ label_requirement_list: Requirement list
+ label_x_biding_project: #modify by men
+ zero: project
+ one: project
+ other: projects
+ #end
+ label_x_responses: #modify by men
+ zero: comment
+ one: comment
+ other: comments
+ #end
+ label_x_followers: #modified by men
+ zero: follower
+ one: follower
+ other: followers
+ #end
+
+
+
+ label_price: price:
+ label_RMB_sign: ¥
+ label_investment_budget: Investment budget:
+ label_investment_time_limit: Investment time limit:
+ label_my_respond: Feedbacks: # modified by bai
+ label_respond_requirement: has commented this call
+ label_deadline: deadline yyyy-mm-dd
+ label_requirement_name: give your requirement a name ~~
+ label_requirement_description: content:descript your requirement
+ label_requirement_bargain_money: type in your rewards(ex. money, reward, grade)
+ label_wrong_budget: The error format of money
+ label_wrong_date: wrong date format, input right date yyyy-mm-dd
+ button_upload_photo: Upload photo
+ label_leave_me_message: left a message to me
+ label_leave_others_message: leave message to him/her
+ label_leave_a_message: Leave him/her a message:
+ label_new_activities: ' has new activity in' # modified by bai
+ label_new_activity: ' has new activity in'
+ label_i_new_activity: ' have new activity in'
+ label_create_project: had participated in
+ label_praise: praise
+ label_cancel_praise: cancel praise
+ label_bid_reason: Please show your reason
+ default_tracker_task: Task
+ label_create_new_projects_description: Create a new project, you will open a magical journey of collaborative creation and development!
+ label_call_for_bids_description: Publish your call for anything, feel the excitement of hundreds respond to a single call!
+ label_create_course_description: Create a new course, let us share the public resources in the course community which are more than you can imagine!
+ label_news: News
+ label_news_description: Track the latest activities of projects, and obtain the latest information!
+ label_milestone: Milestone
+ label_milestone_description: Review the commits, branches and versions of your project!
+ label_features: Features
+ label_has_praisers: praisers(%{count})
+ label_has_watchers: following(%{count}) # modified by bai
+ label_has_fans: followed by(%{count}) # modified by bai
+ #modify by men
+ label_x_has_fans:
+ zero: fan(%{count})
+ one: fan(%{count})
+ other: fans(%{count})
+ #end
+ label_me: me
+ label_my: my
+ label_i: I
+ label_join_bidding: joined the bidding
+ label_bidding_user: Bidding user:
+ label_bidding_reason: Bidding reason:
+ label_username: username:
+ label_password: password:
+ label_about_requirement: about requirement:
+ label_about_issue: about issue:
+ label_quote_my_words: ' quoted my words'
+ label_have_respond: had a respond
+ label_welcome: Welcome
+
+ label_join: join Trustie!
+ label_repository_new: link to existing SVN repository
+ label_repository_path: path of repository
+ label_repository_new_repos: create a new repository
+ label_repository_no: have no repository?
+ label_welcome_page_to: Participate %{project_count} projects!
+ label_repository_path_not_null: repository path can't be null
+ label_password_not_null: password can't be blank
+ label_exist_repository_path: Define exist repository's path of URL and format must be file:///, http://, https://, svn://
+ label_project_no_activity: The project has no activities now!
+ label_follow_no_requirement: You don't have followed any requirements!
+ label_no_user_respond_you: There is no respond for you!
+ label_tags_issue: issue:
+ label_tags_project_name: Project name:
+ label_tags_project_description: Project description:
+ label_tags_user_mail: User E-mail:
+ label_tags_user_name: User Name:
+ label_tags_numbers: Tag numbers:
+ label_max_number: Must be at most 25 characters long.
+ label_all_revisions: All revisions:
+ label_repository_name: Repository name
+ label_upassword_info: The password can be shared in the group
+ label_how_commit_code: How to commit code:
+ label_how_commit_code_chinese: Chinese
+ label_welcome_leave_message: Hi!The platform is currently in beta version.If you have any comments and suggestions, please
+ label_welcome_click_me: Click me
+ label_issue_praise: Good question,praise!
+ label_issue_tread: Poor question,tread!
+ label_issue_praise_over: Praised over!
+ label_issue_tread_over: Treaded over!
+ label_issue_appraise_over: Appraised over!
+ label_welcome_my_respond: Please leave your comments and suggestions here!
+ label_no_current_fans: the user has no fans now
+ label_no_current_watchers: the user hasn't watched others
+ label_project_tool_response: Response
+ label_tags_search_result: Search Results
+ label_active_call: call
+ label_tags_call: Calls
+ label_user_extensions: Other information
+ label_boy: Man
+ label_girl: Woman
+ field_gender: Gender
+ field_birthday: Birthday
+ field_brief_introduction: Info
+ field_location: Location
+ field_occupation: Position
+ field_work_experience: Work experience(year)
+ field_zip_code: Zip code
+ label_reward: reward:
+ label_credit: credit:
+ label_choose_reward: choose reward
+ label_money: money
+ label_reward_1: others
+ label_bids_credit: credit
+ label_bids_credit_number: points
+ field_budget: reward
+ field_deadline: deadline
+ label_tags_selected: Selected Tags
+ label_tags_related: Related Tags
+ button_project_tags_add: Add
+ label_issue_query_condition: Query condition
+ label_homework_source: Task
+ label_issue_query: Query
+ label_issue_cancel_query: Cancel query
+ field_reward_type: The type of reward
+ label_tags_no: no tags now!
+ label_bid_publish: published
+ label_bid_project: projects
+ label_project_no_follow: The project hasn't been followed now!
+ label_no_bid_project: has no participate project
+ label_bids_reward_method: reward:
+ label_bids_reward_what: input what for reward
+ label_call_bonus: bonus
+ label_bids_form_new_description: Publish a requirement,a competition or a course work.
+ label_bids_new_money: input the award money,such as 500,2.5 etc.
+ label_bids_new_credit: input the work corresponding course credits,such as 3,2.5 etc.
+ label_bids_new_content: input the award content,such as certificate,things etc.
+ label_user_login_tips: You havn't logged in,for leaving message please login first
+ label_user_login_new: login
+ label_project_sort: the way of sorting
+ #modified by bai
+ label_sort_by_time: sorted by time
+ label_sort_by_active: sorted by active
+ label_sort_by_influence: sorted by influence
+ #end
+ label_bids_published: published
+ label_bids_published_ago: ago
+ label_welcome_trustie: Trustie forge
+ label_welcome_trustie_description: a socialized collaboration platform for project management, collaborative research, software development and software crowdsourcing for creative university students and entrepreneurs.
+ label_user_project: Projects
+ label_bid_respond_quote: Respond
+ label_bid_if_agreement: If you like me, please press me #bai
+ label_bid_respond_delete: Delete
+ label_newfeedback_message: messages
+ label_newfeedback_quote: Respond
+ label_newfeedback_delete: Delete
+ label_user_all_activity: All activities
+ label_user_activity_myself: About me
+ label_user_all_respond: All replies
+ label_layouts_feedback: Messages
+ label_welcome_participate: participates
+ #modify by men
+ label_x_welcome_participate:
+ zero: participate
+ one: participate
+ other: participates
+ #end
+ label_welcome_participate_project: projects
+ label_projects_feedback: responded to the project
+ label_projects_feedback_respond: Respond
+ label_projects_feedback_respond_success: Respond success
+ button_projects_feedback_respond: Respond
+ label_projects_feedback_respond_content: Please input your words
+ label_in_issues: in the issue:
+ label_in_bids: in the call:
+ label_in_users: in the user:
+ label_user_create_project: has created
+
+#added by bai
+ label_identity: Identity
+ label_teacher: Teacher
+ label_student: Student
+ label_other: Other
+ label_gender: Gender
+ label_gender_male: male
+ label_gender_female: female
+ label_location: Location
+#end
+ label_course: Course
+ label_course_new: New course
+ label_public_info: If you don't choose public, only the project's members can see the project.
+ label_course_student: Student
+ label_homework: Task
+ label_course_new_homework: New homework
+ label_course_homework_list: Homework List
+ label_course_homework_new: new homework
+
+ label_x_course_data:
+ zero: File
+ one: File
+ other: Files
+
+ label_x_base_courses_student:
+ zero: student
+ one: students
+ other: students
+ label_x_base_courses_teacher:
+ zero: teacher
+ one: teachers
+ other: teachers
+ #add by men
+ label_brief_introduction: Personality words
+ label_technical_title: Title
+ label_technicl_title_professor: Professor
+ label_technicl_title_associate_professor: Associate professor
+ label_technicl_title_lecturer: Lecturer
+ label_technicl_title_teaching_assistant: Teaching assistant
+ label_account_identity_teacher: Teacher
+ label_account_identity_student: Student
+ label_account_identity_developer: Developer
+ label_account_identity_enterprise: Enterprise
+ label_account_identity_choose: --Please choose your identity--
+ label_enter_college: College Entrance
+ lable_enter_enterprise: Enterprise Entrance
+ label_homework_info: Status
+ label_question_student: Feedback
+ label_student_response: Feedback
+ label_my_question: Please raise your questions here!
+ label_teacher_homework: Teacher's name
+ label_course_homework: Corresponding course
+ label_limit_time: Deadline
+ label_commit_homework: Submitted Task
+ label_no_course_project: No submitted work!
+ button_clear_requirement: Cancel
+#end
+ label_x_bids_responses: #modify by huang
+ zero: response
+ one: response
+ other: responses
+ #end
+ label_teaching_course: My Courses
+ label_release_homework: Released Tasks
+ label_term: Term
+ label_spring: spring term
+ label_summer: summer term
+ label_autumn: autumn term
+ label_winter: winter term
+ text_command: The password is required when applying a course, and it will be released by the teacher of.
+ label_enterprise_into: Enterprise Entrance
+ label_college_into: College Entrance
+ label_user_course: Courses
+ label_new_course: Courses
+ field_tea_name: Teacher
+ label_course_college: College
+ label_x_task:
+ zero: Task
+ one: Task
+ other: Tasks
+ label_project_course_unadd: You have no course,creat one now!
+ label_my_create_honework_no_homework: no task now!
+ label_my_homework_no_homework: no task now!
+ label_x_member:
+ zero: member
+ one: member
+ other: members
+ label_x_data:
+ zero: file
+ one: file
+ other: files
+ label_bid_show_course_name: Course
+ label_bid_show_teacher_name: Teacher
+ label_bid_contest_show_course_name: Course
+ label_bid_contest_show_teacher_name: Teacher
+ label_x_homework_project:
+ zero: submitted task
+ one: submitted task
+ other: submitted tasks
+ label_new_homework: Tasks
+ label_new_contest: Contests
+ label_contest_list: Contests list
+ label_newtype_contest: Release contest
+ label_question_requirement: introduce a question!
+ button_bidding_homework: To take part in contest
+ label_bids_form_contest_new_description: Enterprise or college can release a contest here.
+ label_contest_name: Input the name of the contest
+ label_contest_description: Content:description your contest
+ label_main_teacher: Main teacher
+ label_main_term: Term
+ label_teacher_work_unit: Position
+ label_course_overview: Status
+ label_course_file: File
+ label_course_news: News
+
+ label_x_base_courses_member:
+ zero: member
+ one: member
+ other: members
+
+ label_bids_task_list: Tasks list
+ label_join_course: join course
+ label_exit_course: exit course
+ label_new_join: Join
+ label_new_join_order: Please input the course order.
+ label_homeworks_form_new_description: Release a task,the submit form of the task may be accessory or project,setting in the task form.
+ label_course_settings: Setting
+ field_homework_type: Submit form
+ label_task_submit_form_accessory: Submitted as accessory
+ label_task_submit_form_project: Submitted as project
+ label_news_notice: Release course news
+
+ role_of_course: Role
+ label_student: student
+ label_teacher: teacher
+ label_ta: teacher assistant
+ label_in_course: in course
+ label_assign_homework: assigned homewok
+ label_noawards: No awards
diff --git a/config/locales/zh.yml b/config/locales/zh.yml
index 7b766249e..29d1f9f1b 100644
--- a/config/locales/zh.yml
+++ b/config/locales/zh.yml
@@ -716,7 +716,7 @@ zh:
label_sort_higher: 上移
label_sort_lower: 下移
label_sort_lowest: 置底
- label_roadmap: 路线图
+ label_roadmap: 版本路线图 #nyan
label_roadmap_due_in: "截止日期到 %{value}"
label_roadmap_overdue: "%{value} 延期"
label_roadmap_no_issues: 该版本没有问题
@@ -1563,6 +1563,14 @@ zh:
zero: 资料
one: 资料
other: 资料
+ label_x_base_courses_student:
+ zero: 学生
+ one: 学生
+ other: 学生
+ label_x_base_courses_teacher:
+ zero: 教师
+ one: 教师
+ other: 教师
label_homework_statistics: 作业统计
label_technical_title: 职称
@@ -1616,9 +1624,9 @@ zh:
label_contest_list: 竞赛列表
label_x_base_courses_member:
- zero: 成员
- one: 成员
- other: 成员
+ zero: 学生
+ one: 学生
+ other: 学生
label_bids_task_list: 作业列表
label_join_course: 加入课程