X-Git-Url: http://git.osdn.net/view?a=blobdiff_plain;f=app%2Fmodels%2Fballoon.rb;h=dc5fa3c6d549ef4e7d16f094d8734f4998c34f51;hb=cb811687cd15adff98b30f841617e35b8e3ccb85;hp=14143a6d499e91b67586b473ff9a400b7a3c8e5b;hpb=99b1f1d1b08c214e954f1e6970bb5ec4800aaa19;p=pettanr%2Fpettanr.git diff --git a/app/models/balloon.rb b/app/models/balloon.rb index 14143a6d..dc5fa3c6 100644 --- a/app/models/balloon.rb +++ b/app/models/balloon.rb @@ -1,83 +1,75 @@ -class Balloon < ActiveRecord::Base +class Balloon < Peta::Element + load_manifest belongs_to :speech_balloon + belongs_to :speech_balloon_template belongs_to :system_picture validates :speech_balloon_id, :numericality => {:allow_blank => true} + validates :speech_balloon_template_id, :presence => true, :numericality => true, :existence => {:both => false} + validates :speech_balloon_template_classname, :presence => true, :length => {:maximum => 50} validates :system_picture_id, :presence => true, :numericality => true, :existence => {:both => false} validates :x, :presence => true, :numericality => true validates :y, :presence => true, :numericality => true validates :width, :presence => true, :numericality => true, :natural_number => true validates :height, :presence => true, :numericality => true, :natural_number => true + validates :r, :presence => true, :numericality => true # validates :caption, :presence => true -# validates :settings, :presence => true + validates :speech_balloon_template_settings, :boost => {:boost_name => :speech_balloon_template} - def url - '/system_pictures/' + self.system_picture.filename - end - - def visible? au - if au == nil - return false if MagicNumber['run_mode'] == 1 - elsif au.is_a?(Author) - elsif au.is_a?(Admin) - return true - else - return false - end - self.speech_balloon.visible? au + def _y + self.attributes['y'] end - def self.default_page_size - 25 + def url + '/system_pictures/' + self.system_picture.filename end - def self.max_page_size - 100 + def supply_default + self.x = 0 + self.y = 0 + self.width = 100 + self.height = 100 + self.r = 0 +self.system_picture_id = 1 end - def self.page prm = nil - page = prm.to_i - page = 1 if page < 1 - page + def symbol_option + self.speech_balloon.speech_balloon_template.symbol_option 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 + 'panels.publish > 0' end - def self.list page = 1, page_size = self.default_page_size - opt = {} - opt.merge!(Balloon.list_opt) - opt.merge!({:limit => page_size, :offset => (page -1) * page_size}) if page_size > 0 - opt.merge!({:conditions => 'panels.publish > 0', :order => 'balloons.updated_at desc'}) - Balloon.find(:all, opt) + def self.by_author_list_includes + { + :speech_balloon => { + :panel => { + :author => {} + } + } + } end - def self.list_opt - {:include => {:speech_balloon => {:panel => {:author => {}}, :speeches => {}, :speech_balloon_template => {} }}} + def self.show_opt + {:include => {:speech_balloon => {:panel => {:author => {}}, :speech => {}, :speech_balloon_template => {} }}} end - def self.list_json_opt - {:include => {:speech_balloon => {:include => {:panel => {:include => {:author => {} }}, :speeches => {}, :speech_balloon_template => {} }}}} + def style + { + 'width' => self.width.to_s + 'px','height' => self.height.to_s + 'px', + 'top' => self._y.to_s + 'px','left' => self.x.to_s + 'px' + } end - def self.show cid, au - opt = {} - opt.merge!(Balloon.show_opt) - res = Balloon.find(cid, opt) - raise ActiveRecord::Forbidden unless res.visible?(au) - res + def self.panelize balloon_attributes + {'balloon_attributes' => balloon_attributes} end - def self.show_opt - {:include => {:speech_balloon => {:panel => {:author => {}}, :speeches => {}, :speech_balloon_template => {} }}} + def scenario end - def self.show_json_opt - {:include => {:speech_balloon => {:include => {:panel => {:include => {:author => {} }}, :speeches => {}, :speech_balloon_template => {} }}}} + def plain_scenario end end