parent
d09e141ab0
commit
5d36f8c9ed
@ -0,0 +1,15 @@
|
||||
class Weapps::UpdateCourseForm
|
||||
include ActiveModel::Model
|
||||
|
||||
attr_accessor :course
|
||||
attr_accessor :name, :course_list_name, :credit
|
||||
|
||||
validates :name, presence: true
|
||||
validates :course_list_name, presence: true
|
||||
|
||||
validate :course_name_prefix
|
||||
|
||||
def course_name_prefix
|
||||
raise '课堂名称应以课程名称开头' unless name.index(course_list_name) && name.index(course_list_name) == 0
|
||||
end
|
||||
end
|
@ -0,0 +1,31 @@
|
||||
class Weapps::UpdateCourseService < ApplicationService
|
||||
attr_reader :course, :params
|
||||
|
||||
def initialize(course, params)
|
||||
@course = course
|
||||
@params = params
|
||||
end
|
||||
|
||||
def call
|
||||
Weapps::UpdateCourseForm.new(form_params).validate!
|
||||
|
||||
ActiveRecord::Base.transaction do
|
||||
course.name = params[:name].to_s.strip
|
||||
course.credit = params[:credit].blank? ? nil : params[:credit]
|
||||
course_list = CourseList.find_by(name: params[:course_list_name].to_s.strip)
|
||||
if course_list
|
||||
course.course_list_id = course_list.id
|
||||
else
|
||||
new_course_list = CourseList.create!(name: params[:course_list_name].to_s.strip, user_id: course.tea_id, is_admin: 0)
|
||||
course.course_list_id = new_course_list.id
|
||||
end
|
||||
course.save!
|
||||
end
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def form_params
|
||||
params.merge(course: course)
|
||||
end
|
||||
end
|
@ -0,0 +1,2 @@
|
||||
json.(@course, :id, :name, :credit)
|
||||
json.course_list_name @course.course_list&.name
|
Loading…
Reference in new issue