|
|
@ -484,6 +484,7 @@ class ProjectsController < ApplicationController
|
|
|
|
|
|
|
|
|
|
|
|
@course_tag = params[:project][:project_type]
|
|
|
|
@course_tag = params[:project][:project_type]
|
|
|
|
if(@course_tag=="1")
|
|
|
|
if(@course_tag=="1")
|
|
|
|
|
|
|
|
if User.current.user_extensions.identity == 0
|
|
|
|
@course = Course.new
|
|
|
|
@course = Course.new
|
|
|
|
@course.extra='course' + DateTime.parse(Time.now.to_s).strftime('%Y-%m-%d_%H-%M-%S').to_s
|
|
|
|
@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.safe_attributes = params[:project][:course]
|
|
|
@ -491,6 +492,7 @@ class ProjectsController < ApplicationController
|
|
|
|
# added by bai
|
|
|
|
# added by bai
|
|
|
|
@course.term = params[:term]
|
|
|
|
@course.term = params[:term]
|
|
|
|
@course.time = params[:time]
|
|
|
|
@course.time = params[:time]
|
|
|
|
|
|
|
|
end
|
|
|
|
# end
|
|
|
|
# end
|
|
|
|
# @course.save
|
|
|
|
# @course.save
|
|
|
|
# project = ProjectInfo.create(:user_id => User.current.id, :project_id => @project.id)
|
|
|
|
# project = ProjectInfo.create(:user_id => User.current.id, :project_id => @project.id)
|
|
|
@ -504,55 +506,57 @@ class ProjectsController < ApplicationController
|
|
|
|
@project.identifier = @course.extra
|
|
|
|
@project.identifier = @course.extra
|
|
|
|
end
|
|
|
|
end
|
|
|
|
if @course_tag == '1'
|
|
|
|
if @course_tag == '1'
|
|
|
|
if@course.save
|
|
|
|
if User.current.user_extensions.identity == 0
|
|
|
|
if validate_parent_id && @project.save
|
|
|
|
if@course.save
|
|
|
|
@project.set_allowed_parent!(params[:project]['parent_id']) if params[:project].has_key?('parent_id')
|
|
|
|
if validate_parent_id && @project.save
|
|
|
|
# Add current user as a project member if he is not admin
|
|
|
|
@project.set_allowed_parent!(params[:project]['parent_id']) if params[:project].has_key?('parent_id')
|
|
|
|
unless User.current.admin?
|
|
|
|
# Add current user as a project member if he is not admin
|
|
|
|
r = Role.givable.find_by_id(Setting.new_project_user_role_id.to_i) || Role.givable.first
|
|
|
|
unless User.current.admin?
|
|
|
|
m = Member.new(:user => User.current, :roles => [r])
|
|
|
|
r = Role.givable.find_by_id(Setting.new_project_user_role_id.to_i) || Role.givable.first
|
|
|
|
project = ProjectInfo.new(:user_id => User.current.id, :project_id => @project.id)
|
|
|
|
m = Member.new(:user => User.current, :roles => [r])
|
|
|
|
if params[:project][:is_public] == '1' || @course_tag=="1"
|
|
|
|
project = ProjectInfo.new(:user_id => User.current.id, :project_id => @project.id)
|
|
|
|
project_status = ProjectStatus.create(:project_id => @project.id, :watchers_count => 0, :changesets_count => 0, :project_type => @course_tag)
|
|
|
|
if params[:project][:is_public] == '1' || @course_tag=="1"
|
|
|
|
end
|
|
|
|
project_status = ProjectStatus.create(:project_id => @project.id, :watchers_count => 0, :changesets_count => 0, :project_type => @course_tag)
|
|
|
|
@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
|
|
|
|
end
|
|
|
|
}
|
|
|
|
@project.members << m
|
|
|
|
format.api { render :action => 'show', :status => :created, :location => url_for(:controller => 'projects', :action => 'show', :id => @project.id) }
|
|
|
|
@project.project_infos << project
|
|
|
|
end
|
|
|
|
end
|
|
|
|
else
|
|
|
|
respond_to do |format|
|
|
|
|
@course.destroy
|
|
|
|
format.html {
|
|
|
|
respond_to do |format|
|
|
|
|
flash[:notice] = l(:notice_successful_create)
|
|
|
|
format.html { render :action => 'new', :layout => 'base'}#Added by young
|
|
|
|
if params[:continue]
|
|
|
|
format.api { render_validation_errors(@project) }
|
|
|
|
attrs = {:parent_id => @project.parent_id}.reject {|k,v| v.nil?}
|
|
|
|
end
|
|
|
|
redirect_to new_project_path(attrs, :course => '0')
|
|
|
|
end
|
|
|
|
#Added by young
|
|
|
|
else
|
|
|
|
|
|
|
|
if validate_parent_id && @project.save
|
|
|
|
elsif params[:course_continue]
|
|
|
|
@project.delete
|
|
|
|
redirect_to new_project_path(:course => '1')
|
|
|
|
respond_to do |format|
|
|
|
|
#Ended by young
|
|
|
|
format.html { render :action => 'new', :layout => 'base'}#Added by young
|
|
|
|
else
|
|
|
|
format.api { render_validation_errors(@project) }
|
|
|
|
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
|
|
|
|
end
|
|
|
|
else
|
|
|
|
else
|
|
|
|
respond_to do |format|
|
|
|
|
if validate_parent_id && @project.save
|
|
|
|
format.html { render :action => 'new', :layout => 'base'}#Added by young
|
|
|
|
@project.delete
|
|
|
|
format.api { render_validation_errors(@project) }
|
|
|
|
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
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|