X-Git-Url: http://git.osdn.net/view?a=blobdiff_plain;f=app%2Fmodels%2Fauthor.rb;h=0ea5aab93e2534a2f94437482e6729e4f442bb26;hb=cc2dbf353c285c78423a8a29d7adf233e1651c6e;hp=980da84e36ba6f974aa670e78cc31b6dba806521;hpb=e5489fabe79c2e0c28a61e7af03162e9f8b4bdfe;p=pettanr%2Fpettanr.git diff --git a/app/models/author.rb b/app/models/author.rb index 980da84e..0ea5aab9 100644 --- a/app/models/author.rb +++ b/app/models/author.rb @@ -1,135 +1,27 @@ -class Author < ActiveRecord::Base - has_one :artist +class Author < Peta::Owner + load_manifest belongs_to :user + has_many :scrolls + has_many :comics + has_many :sheets + has_many :panels + belongs_to :working_panel, :class_name => "Panel" - validates :name, :length => {:maximum => 30} + validates :name, :presence => true, :length => {:maximum => 30} + validates :working_panel_id, :numericality => {:allow_nil => true} + validates :user_id, :numericality => true, :existence => {:both => false} - before_save do |r| - r.name = 'no name' if r.name.blank? + def supply_default + self.name = 'no name' if self.name.blank? + self.user_id = nil end - def artist? - Artist.find_by_author(self) != nil + def working? + self.working_panel_id and self.working_panel end - def step2 n - self.name = n - self.save - end - - def self.default_page_size - 25 - end - - def self.max_page_size - 100 - 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!({:order => 'updated_at desc', :limit => page_size, :offset => (page -1) * page_size}) - Author.find(:all, opt) - end - - def self.list_opt - {:include => :artist} - end - - def self.list_json_opt - {:include => :artist} - end - - def self.default_comic_page_size - 30 - end - - def self.comic_max_page_size - 200 - end - - def self.comic_page_size prm = self.default_comic_page_size - page_size = prm.to_i - page_size = self.comic_max_page_size if page_size > self.comic_max_page_size - page_size = self.default_comic_page_size if page_size < 1 - page_size - end - - def self.default_story_page_size - 30 - end - - def self.story_max_page_size - 200 - end - - def self.story_page_size prm = self.default_story_page_size - page_size = prm.to_i - page_size = self.story_max_page_size if page_size > self.story_max_page_size - page_size = self.default_story_page_size if page_size < 1 - page_size - end - - def self.default_panel_page_size - 30 - end - - def self.panel_max_page_size - 200 - end - - def self.panel_page_size prm = self.default_panel_page_size - page_size = prm.to_i - page_size = self.panel_max_page_size if page_size > self.panel_max_page_size - page_size = self.default_panel_page_size if page_size < 1 - page_size - end - - def self.default_panel_picture_page_size - 30 - end - - def self.panel_picture_max_page_size - 200 - end - - def self.panel_picture_page_size prm = self.default_panel_picture_page_size - page_size = prm.to_i - page_size = self.panel_picture_max_page_size if page_size > self.panel_picture_max_page_size - page_size = self.default_panel_picture_page_size if page_size < 1 - page_size - end - - def self.show aid, opt = {} - a = Author.find(aid, :include => self.show_include_opt(opt)) -# raise ActiveRecord::Forbidden unless c.visible?(au) - a - end - - def self.show_include_opt opt = {} - res = [:artist] - res.push(opt[:include]) if opt[:include] - res - end - - def self.show_json_include_opt - {:include => :artist} - end - - def self.visible_count - Author.count + def self.show_opt + {:include => {:user => {:artist => {}}} } end end