X-Git-Url: http://git.osdn.net/view?a=blobdiff_plain;f=app%2Fmodels%2Fcomic.rb;h=5b7f9dc111606326fd59e61d0ff9dbdedbf06de9;hb=31124ac1df4b11438308bb83525753b3e40e355a;hp=b280dd330f92768a22a058cd3af2d50466fc80b4;hpb=2983ab721a7fbeb9568a1b291ce30afc93a10f03;p=pettanr%2Fpettanr.git diff --git a/app/models/comic.rb b/app/models/comic.rb index b280dd33..5b7f9dc1 100644 --- a/app/models/comic.rb +++ b/app/models/comic.rb @@ -1,129 +1,95 @@ -class Comic < ActiveRecord::Base - has_many :panels, :dependent => :destroy +#コミック +class Comic < Peta::Content + load_manifest + has_many :stories, :order => 't' belongs_to :author - validates :title, :presence => true, :length => {:maximum => 100} - validates :width, :presence => true, :numericality => true, :natural_number => true - validates :height, :presence => true, :numericality => true, :natural_number => true - validates :visible, :presence => true, :numericality => true, :inclusion => {:in => 0..3} - validates :editable, :presence => true, :numericality => true, :inclusion => {:in => 0..3} + validates :title, :presence => true, :length => {:maximum => 100} + validates :visible, :presence => true, :numericality => true, :inclusion => {:in => 0..1} + validates :author_id, :presence => true, :numericality => true, :existence => {:both => false} - before_save do |r| - r.supply_default + def self.visible_count_options + {:conditions => 'visible > 0'} end def supply_default self.visible = 0 if self.visible.blank? - self.editable= 0 if self.editable.blank? end - def own? author - return false unless author - self.author_id == author.id + def overwrite operators + return false unless operators.author + self.author_id = operators.author.id end - def visible? author - self.visible > 0 or self.own?(author) + def visible? operators + case super + when nil # super return + return true + when false + return false + else + self.visible > 0 + end end - def disp_editable - editable == 1 ? 'O' : 'X' + def comic_stories_count + Story.where(['stories.comic_id = ?', self.id]).count end - def disp_visible - visible == 1 ? 'O' : 'X' + def symbol_filename end - def self.default_page_size - 25 + def self.public_list_where + 'comics.visible > 0' end - def self.max_page_size - 100 - end - - def self.default_panel_size - 30 - end - - def self.max_panel_size - 200 - end - - def self.page prm = nil - page = prm.to_i - page = 1 if page < 1 - page - end - - def self.page_size prm = self.default_page_size - page_size = prm.to_i - page_size = self.max_page_size if page_size > self.max_page_size - page_size = self.default_page_size if page_size < 1 - page_size - end - - def self.offset cnt, prm = nil - offset = prm.to_i - offset = cnt - 1 if offset >= cnt - offset = cnt - offset.abs if offset < 0 - offset = 0 if offset < 0 - offset - end - - def self.panel_count cnt, prm = self.default_panel_size - count = prm.to_i - count = self.max_panel_size if count > self.max_panel_size - count = self.default_panel_size if count < 1 - count - end - - def self.list opt = {}, page = 1, page_size = self.default_page_size - opt.merge!(self.list_opt) unless opt[:include] - opt.merge!({:conditions => ['visible > 0'], :order => 'updated_at desc', :limit => page_size, :offset => (page -1) * page_size}) - Comic.find(:all, opt) + def self.list_order + 'comics.updated_at desc' end def self.list_opt - {:include => :author} + {:stories => {}, :author => {} } end def self.list_json_opt - {:include => :author} + {:include => {:stories => {}, :author => {}} } end - def self.show cid, au, opt = {} - c = Comic.find(cid, :include => self.show_include_opt(opt)) - raise ActiveRecord::Forbidden unless c.visible?(au) - c + def self.show_opt + {:include => {:stories => {}, :author => {}} } end - def self.show_include_opt opt = {} - res = [:author] - res.push(opt[:include]) if opt[:include] - res + def self.show_json_opt + {:include => {:stories => {}, :author => {}} } end - def self.show_json_include_opt - {:include => :author} + def tag_attributes column = nil, opt = {} + { + } end - def self.play cid, opt = {} - Comic.find(cid, include: [ - :author, - :panels => [ - :panel_pictures => :resource_picture, - :speech_balloons =>{:balloons => {}, :speeches => {}} - ] - ], order: 'panels.t') + def destroy_with_story + res = false + Comic.transaction do + self.stories.each do |story| + raise ActiveRecord::Rollback unless story.destroy_and_shorten + end + raise ActiveRecord::Rollback unless self.destroy + res = true + end + res end - def to_json_play - self.to_json( :include => {:author => {}, :panels => {:methods => :panel_element}}) + def scenario + panels.map {|panel| + panel.scenario + }.join end - def self.visible_count - Comic.count 'visible > 0' + def plain_scenario + panels.map {|panel| + panel.plain_scenario + }.join end end