X-Git-Url: http://git.osdn.net/view?a=blobdiff_plain;f=app%2Fmodels%2Fcomic.rb;h=ed15468c6be4b4e85492483fa5b4c07ee7bc56e5;hb=674d4fb2e72c2e1653b13d026af884559fd9eb4e;hp=13ef9c7605d95b551af01adef496983fd8405008;hpb=27e96fe0cd5c1f268182e17fe2d42d617b08b4f6;p=pettanr%2Fpettanr.git diff --git a/app/models/comic.rb b/app/models/comic.rb index 13ef9c76..ed15468c 100644 --- a/app/models/comic.rb +++ b/app/models/comic.rb @@ -1,101 +1,55 @@ #コミック -class Comic < ActiveRecord::Base - has_many :stories +class Comic < Peta::Binder + load_manifest + has_many :comic_stories 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} - - before_save do |r| - r.supply_default - end + 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? + self.author_id = nil end - def own? author - return false unless author - self.author_id == author.id - end - - def visible? author - self.visible > 0 or self.own?(author) - end - - def disp_visible - visible == 1 ? 'O' : 'X' - 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 - 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.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) - end - - def self.list_opt - {:include => {:stories => {:panel => {}}, :author => {}}} + def overwrite operators + return false unless operators.author + self.author_id = operators.author.id end - def self.list_json_opt - {:include => {:stories => {:panel => {}}, :author => {}}} + def visible? operators + case super + when nil # super return + return true + when false + return false + else + self.visible > 0 + end end - def self.mylist au, opt = {}, page = 1, comic_page_size = Author.default_comic_page_size - opt.merge!(self.list_opt) unless opt[:include] - opt.merge!({:conditions => ['comics.author_id = ?', au.id], :order => 'comics.updated_at desc', :limit => page_size, :offset => (page -1) * comic_page_size}) - Comic.find(:all, opt) + def symbol_filename 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.public_list_where list + 'comics.visible > 0' end - def self.show_include_opt opt = {} - res = {:stories => {:panel => {}}, :author => {}} - res.push(opt[:include]) if opt[:include] - res + def self.show_opt + {:include => {:comic_stories => {:story => {}}, :author => {}}} end - def self.show_json_include_opt - {:include => {:stories => {:panel => {}}, :author => {}}} + 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