X-Git-Url: http://git.osdn.net/view?p=pettanr%2Fpettanr.git;a=blobdiff_plain;f=app%2Fmodels%2Fpanel_picture.rb;h=2406f778c1040909ecc9f84b4cf3424b299124c4;hp=2aa3affbd97a64ef0640c9f377e2916e84e464bd;hb=9edc3731389bcae0de05ef6045cceb6b7581cc8f;hpb=160cfe90adb0a44dd3cdc02962cb5326d2a11585 diff --git a/app/models/panel_picture.rb b/app/models/panel_picture.rb index 2aa3affb..2406f778 100644 --- a/app/models/panel_picture.rb +++ b/app/models/panel_picture.rb @@ -5,7 +5,8 @@ class PanelPicture < Peta::Element validates :panel_id, :numericality => {:allow_blank => true} validates :picture_id, :numericality => true, :existence => {:both => false} - validates :link, :length => {:maximum => 200}, :url => {:allow_blank => true, :message => I18n.t('errors.messages.url')} + validates :link, :length => {:maximum => 200}, :allow_blank => true + #validates :link, :length => {:maximum => 200}, :url => {:allow_blank => true, :message => I18n.t('errors.messages.url')} validates :x, :presence => true, :numericality => true validates :y, :presence => true, :numericality => true validates :width, :presence => true, :numericality => true, :not_zero => true, :reverse => true, :sync_vh => true @@ -13,6 +14,26 @@ class PanelPicture < Peta::Element validates :z, :presence => true, :numericality => {:greater_than => 0} validates :t, :presence => true, :numericality => {:greater_than_or_equal_to => 0} + scope :with_panel, -> do + includes(:panel) + end + + scope :find_index, -> do + with_panel.where(Panel.arel_table[:publish].gt 0).references(:panel) + end + + scope :find_private, -> (operators) do + with_panel.where(Panel.arel_table[:author_id].eq operators.author.id).references(:panel) + end + + scope :find_by_panel, -> (panel_id) do + find_index.where(panel_id: panel_id).references(:panel) + end + + scope :find_by_author, -> (author_id) do + find_index.where(Panel.arel_table[:author_id].eq author_id).references(:panel) + end + def self.pickup_item_name Picture.item_name end @@ -67,7 +88,8 @@ class PanelPicture < Peta::Element end def filename - self.picture.filename + '?subdir=' + self.flip + q = self.flip.empty? ? '' : '?subdir=' + self.flip + self.picture.filename + q end def url @@ -96,7 +118,7 @@ class PanelPicture < Peta::Element self.picture.symbol_option end - def self.public_list_where + def self.public_list_where list 'panels.publish > 0' end @@ -104,6 +126,14 @@ class PanelPicture < Peta::Element {:include => {:panel => {:author => {}}, :picture => {:artist => {}, :license => {}}}} end + def disp_link + if self.link =~ /\:\/\// + self.link + else + '/' + self.link.to_s + end + end + def scenario if caption.blank? ''