X-Git-Url: http://git.osdn.net/view?a=blobdiff_plain;f=app%2Fmodels%2Fcomic.rb;h=fbb04e2768136f96b4a28e3626aa8b992f473668;hb=02ea4fc4bbe7a54dd576c1cd700aa9e32710abf8;hp=c60e5197b0fc63924314ec8d80ea3e17c068e2bf;hpb=fb5769ff710c952a6b9ed3ce2ee74a6dfdc334cf;p=pettanr%2Fpettanr.git diff --git a/app/models/comic.rb b/app/models/comic.rb index c60e5197..fbb04e27 100644 --- a/app/models/comic.rb +++ b/app/models/comic.rb @@ -1,10 +1,14 @@ #コミック -class Comic < ActiveRecord::Base - has_many :stories +class Comic < Pettanr::Content + 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} + + @@valid_encode_columns += ['title', 'description'] + @@visible_count_options = {:conditions => 'visible > 0'} def supply_default self.visible = 0 if self.visible.blank? @@ -15,109 +19,71 @@ class Comic < ActiveRecord::Base self.author_id = au.id end - def own? roles - roles = [roles] unless roles.respond_to?(:each) - au = Comic.get_author_from_roles roles - return false unless au - self.author_id == au.id - end - - def visible? roles - if MagicNumber['run_mode'] == 0 - return false unless guest_role_check(roles) - else - return false unless reader_role_check(roles) - end - return true if self.own?(roles) + def visible? operators + super self.visible > 0 end - def self.default_page_size - 25 + def comic_stories_count + Story.where(['stories.comic_id = ?', self.id]).count end - def self.max_page_size - 100 + def symbol_filename end - def self.default_panel_size - 30 + def self.list_where + 'comics.visible > 0' end - def self.max_panel_size - 200 + def self.list_order + 'comics.updated_at desc' end - def self.page prm = nil - page = prm.to_i - page = 1 if page < 1 - page + def self.mylist_where me + ['comics.author_id = ?', me.id] 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.mylist_order + 'comics.updated_at desc' 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.himlist_where anybody + ['comics.author_id = ? and comics.visible > 0', anybody.id] end - def self.list_opt - {:include => {:stories => {:panel => {}}, :author => {}}} + def self.himlist_order + 'comics.updated_at desc' end - def self.list_json_opt - {:include => {:stories => {:include => {:panel => {}}}, :author => {}}} + def self.list_by_author_where author_id + ['comics.author_id = ?', author_id] 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) + def self.list_by_author author_id, roles, page = 1, page_size = self.default_page_size + self.where(self.list_by_author_where(author_id)).includes(self.list_opt).order('comics.updated_at desc').offset((page -1) * page_size).limit(page_size) end - def self.show cid, roles - opt = {} - opt.merge!(Comic.show_opt) - res = Comic.find(cid, opt) - raise ActiveRecord::Forbidden unless res.visible?(roles) - res + def self.list_opt + {:stories => {}, :author => {} } 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 + def self.list_json_opt + {: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 => {}}} - end - - def self.visible_count - Comic.count 'visible > 0' + {:include => {:stories => {}, :author => {}} } 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 @@ -125,4 +91,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