X-Git-Url: http://git.osdn.net/view?a=blobdiff_plain;f=app%2Fmodels%2Fcomic.rb;h=5b7f9dc111606326fd59e61d0ff9dbdedbf06de9;hb=84a5b0cfc30cd42930ee80551ba389b223643dc3;hp=e9b1298243962c9f745e39a6e41f1c763e685810;hpb=92e42b345715a552a4ce833b03ec68aed94792e0;p=pettanr%2Fpettanr.git diff --git a/app/models/comic.rb b/app/models/comic.rb index e9b12982..5b7f9dc1 100644 --- a/app/models/comic.rb +++ b/app/models/comic.rb @@ -1,122 +1,78 @@ #コミック -class Comic < ActiveRecord::Base - has_many :stories +class Comic < Peta::Content + load_manifest + has_many :stories, :order => 't' belongs_to :author 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} - def supply_default - self.visible = 0 if self.visible.blank? + def self.visible_count_options + {:conditions => 'visible > 0'} end - def overwrite au - return false unless au - self.author_id = au.id + def supply_default + self.visible = 0 if self.visible.blank? end - def own? au - return false unless au.is_a?(Author) - self.author_id == au.id + def overwrite operators + return false unless operators.author + self.author_id = operators.author.id end - def visible? au - if au == nil - return false if MagicNumber['run_mode'] == 1 - elsif au.is_a?(Author) - return true if self.own?(au) - else + def visible? operators + case super + when nil # super return + return true + when false return false + else + self.visible > 0 end - self.visible > 0 - end - - def self.default_page_size - 25 - end - - def self.max_page_size - 100 - end - - def self.default_panel_size - 30 end - def self.max_panel_size - 200 + def comic_stories_count + Story.where(['stories.comic_id = ?', self.id]).count end - def self.page prm = nil - page = prm.to_i - page = 1 if page < 1 - page + def symbol_filename 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 + def self.public_list_where + 'comics.visible > 0' end - def self.list page = 1, page_size = self.default_page_size - opt = {} - opt.merge!(Comic.list_opt) - opt.merge!({:limit => page_size, :offset => (page -1) * page_size}) if page_size > 0 - opt.merge!({:conditions => ['visible > 0'], :order => 'updated_at desc'}) - Comic.find(:all, opt) + def self.list_order + 'comics.updated_at desc' end def self.list_opt - {:include => {:stories => {:panel => {}}, :author => {}}} + {:stories => {}, :author => {} } end def self.list_json_opt - {:include => {:stories => {:include => {:panel => {}}}, :author => {}}} - end - - def self.mylist au, page = 1, page_size = Author.default_comic_page_size - opt = {} - opt.merge!(Comic.list_opt) - opt.merge!({:limit => page_size, :offset => (page -1) * page_size}) if page_size > 0 - opt.merge!({:conditions => ['comics.author_id = ?', au.id], :order => 'comics.updated_at desc'}) - Comic.find(:all, opt) - end - - def self.show cid, au - opt = {} - opt.merge!(Comic.show_opt) - res = Comic.find(cid, opt) - raise ActiveRecord::Forbidden unless res.visible?(au) - res - end - - def self.edit cid, au - opt = {} - opt.merge!(Comic.show_opt) - res = Comic.find(cid, opt) - raise ActiveRecord::Forbidden unless res.own?(au) - res + {:include => {:stories => {}, :author => {}} } end def self.show_opt - {:include => {:stories => {:panel => {}}, :author => {}}} + {:include => {:stories => {}, :author => {}} } end def self.show_json_opt - {:include => {:stories => {:include => {:panel => {}}}, :author => {}}} + {:include => {:stories => {}, :author => {}} } end - def self.visible_count - Comic.count 'visible > 0' + def tag_attributes column = nil, opt = {} + { + } end def destroy_with_story res = false Comic.transaction do self.stories.each do |story| - raise ActiveRecord::Rollback unless story.destroy + raise ActiveRecord::Rollback unless story.destroy_and_shorten end raise ActiveRecord::Rollback unless self.destroy res = true @@ -124,4 +80,16 @@ class Comic < ActiveRecord::Base res end + def scenario + panels.map {|panel| + panel.scenario + }.join + end + + def plain_scenario + panels.map {|panel| + panel.plain_scenario + }.join + end + end