Sha256: 0045814558f1fc3d466a18177f7579c95a3d070b6315508f65160df0d40cb494
Contents?: true
Size: 1.86 KB
Versions: 8
Compression:
Stored size: 1.86 KB
Contents
class Book < Content numbered :chapters aggregate_of :chapters has_many :chapters, -> { order(number: :asc) }, dependent: :destroy has_many :complements, dependent: :destroy has_many :exercises, through: :chapters has_many :discussions, through: :exercises organic_on :discussions delegate :first_lesson, to: :first_chapter def to_s slug end def first_chapter chapters.first end def next_lesson_for(user) user.try(:last_lesson)|| first_lesson end after_save :reindex_usages! def import_from_resource_h!(resource_h) self.assign_attributes resource_h.except(:chapters, :complements, :id, :description) self.description = resource_h[:description]&.squeeze(' ') rebuild! resource_h[:chapters].map { |it| Topic.find_by!(slug: it).as_chapter_of(self) } rebuild_complements! resource_h[:complements].to_a.map { |it| Guide.find_by(slug: it)&.as_complement_of(self) }.compact end def to_resource_h super.merge( chapters: chapters.map(&:slug), complements: complements.map(&:slug)) end def rebuild_complements!(complements) #FIXME use rebuild transaction do self.complements.all_except(complements).delete_all self.update! :complements => complements complements.each &:save! end reload end def index_usage!(organization) organization.index_usage_of! self, self [chapters, complements].flatten.each { |item| item.index_usage! organization } end def reindex_usages! Organization.where(book: self).each &:reindex_usages! end ## Forking def fork_children_into!(dup, organization, syncer) dup.chapters = chapters.map { |chapter| chapter.topic.fork_to!(organization, syncer, quiet: true).as_chapter_of(dup) } dup.complements = complements.map { |complement| complement.guide.fork_to!(organization, syncer, quiet: true).as_complement_of(dup) } end end
Version data entries
8 entries across 8 versions & 1 rubygems