X-Git-Url: http://git.osdn.net/view?a=blobdiff_plain;f=app%2Fmodels%2Fballoon.rb;h=bf3d7f46661a014a36ac558b5dc36f7025e0ca39;hb=279324e2ea829a8e13358a850335cbd765e98fe5;hp=2947caa15a1ff422131af25148d17b2958ae1d61;hpb=5a85a22c60b088f6c51868d32144e46fbbe9ac15;p=pettanr%2Fpettanr.git diff --git a/app/models/balloon.rb b/app/models/balloon.rb index 2947caa1..bf3d7f46 100644 --- a/app/models/balloon.rb +++ b/app/models/balloon.rb @@ -1,8 +1,12 @@ -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_module_name, :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 @@ -10,140 +14,88 @@ class Balloon < ActiveRecord::Base 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} - before_validation :valid_encode - - def valid_encode - ['settings'].each do |a| - next if attributes[a] == nil - raise Pettanr::BadRequest unless attributes[a].valid_encoding? - end - end - - def url - '/system_pictures/' + self.system_picture.filename - 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.speech_balloon.panel.own?(roles) - self.speech_balloon.panel.visible? roles - end - - 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 get_speech_balloon - self.speech_balloon - end - - def get_panel_id - if self.get_speech_balloon == nil or self.get_speech_balloon.panel == nil or self.get_speech_balloon.panel.new_record? - 0 - else - self.get_speech_balloon.panel.id - end - end - - def tag_id c = nil - 'panel' + tag_panel_id + tag_element_type + tag_element_id + tag_element_part_type + tag_element_part_id + c.to_s + scope :with_panel, -> do + includes(speech_balloon: :panel) end - def field_tag_id f - self.tag_id + f.to_s + scope :with_speech_balloon_template, -> do + includes(:speech_balloon_template) end - def tag_panel_id - self.get_panel_id.to_s + scope :find_index, -> do + with_panel.where(Panel.arel_table[:publish].gt 0).references(:panel) end - def tag_element_id - r = if self.get_speech_balloon == nil or self.get_speech_balloon.new_record? - 0 - else - self.get_speech_balloon.id - end - r.to_s + scope :find_private, -> (operators) do + with_panel.where(Panel.arel_table[:author_id].eq operators.author.id).references(:panel) end - def tag_element_type - 'speech_balloon' + scope :find_by_panel, -> (panel_id) do + find_index.where(panel_id: panel_id).references(:panel) end - def tag_element_part_id - self.new_record? ? '0' : self.id.to_s + scope :find_by_speech_balloon, -> (speech_balloon_id) do + find_index.where(speech_balloon_id: speech_balloon_id).references(:panel) end - def tag_element_part_type - 'balloon' + scope :find_by_speech_balloon_template, -> (speech_balloon_template_id) do + find_index.where(speech_balloon_template_id: speech_balloon_template_id).references(:panel) end - def field_tree f - 'panels-' + self.tag_panel_id + '-speech_balloons_attributes-' + self.tag_element_id + '-balloon_attributes-' + f.to_s + scope :find_by_system_picture, -> (system_picture_id) do + find_index.where(system_picture_id: system_picture_id).references(:panel) end - def self.default_page_size - 25 + scope :find_by_author, -> (author_id) do + find_index.where(Panel.arel_table[:author_id].eq author_id).references(:panel) end - def self.max_page_size - 100 + def y + self.attributes['y'] 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 + def url + '/system_pictures/' + self.system_picture.filename 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 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.list_opt - {:include => {:speech_balloon => {:panel => {:author => {}}, :speech => {}, :speech_balloon_template => {} }}} + def symbol_option + self.speech_balloon.speech_balloon_template.symbol_option end - def self.list_json_opt - {:include => {:speech_balloon => {:include => {:panel => {:include => {:author => {} }}, :speech => {}, :speech_balloon_template => {} }}}} + def self.public_list_where list + 'panels.publish > 0' 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.by_author_list_includes + { + :speech_balloon => { + :panel => { + :author => {} + } + } + } end def self.show_opt {:include => {:speech_balloon => {:panel => {:author => {}}, :speech => {}, :speech_balloon_template => {} }}} end - def self.show_json_opt - {:include => {:speech_balloon => {:include => {:panel => {:include => {:author => {} }}, :speech => {}, :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 scenario