OSDN Git Service

merge
[pettanr/pettanr.git] / app / models / resource_picture.rb
index b74b115..521a071 100644 (file)
@@ -7,6 +7,7 @@ class ResourcePicture < Peta::Content
   belongs_to :system_picture
   belongs_to :picture
   belongs_to :original_picture
+  has_many :resource_picture_pictures
   
   validates :ext, :presence => true, :length => {:maximum => 4}, :inclusion => {:in => ['png', 'jpeg', 'gif']}
   validates :width, :presence => true, :numericality => true, :natural_number => true
@@ -23,6 +24,30 @@ class ResourcePicture < Peta::Content
   validates :license_group_settings, :boost => {:boost_name => :license_group}
   validates :credit_picture_settings, :boost => {:boost_name => :credit_picture}
   
+  scope :find_index, -> do
+    self.all
+  end
+  
+  scope :find_private, -> (operators) do 
+    where(artist_id: operators.artist.id)
+  end
+  
+  scope :find_by_original_picture, -> (original_picture_id) do 
+    find_index.where(original_picture_id: original_picture_id)
+  end
+  
+  scope :find_by_license_group, -> (license_group_id) do 
+    find_index.where(license_group_id: license_group_id)
+  end
+  
+  scope :find_by_license, -> (license_id) do 
+    find_index.where(license_id: license_id)
+  end
+  
+  scope :find_by_artist, -> (artist_id) do 
+    find_index.where(artist_id: artist_id)
+  end
+  
   def self.pickup_item_name
     Picture.item_name
   end
@@ -133,7 +158,17 @@ class ResourcePicture < Peta::Content
       pc = self.new_picture imager
       if pc
         self.picture_id = pc.id
+        resource_picture_picture = ResourcePicturePicture.new(
+          :original_picture_id => self.original_picture_id,
+          :resource_picture_id => self.id,
+          :picture_id => pc.id
+        )
+        raise ActiveRecord::Rollback unless resource_picture_picture.save
         if res = self.save
+          self.original_picture.resource_picture_pictures.each do |resource_picture_picture|
+            resource_picture_picture.resource_picture_id = self.id
+            raise ActiveRecord::Rollback unless resource_picture_picture.save
+          end
           res = self.store_picture_with_gif(imager)
         end
       else
@@ -186,6 +221,10 @@ class ResourcePicture < Peta::Content
       self.original_picture.published_at = nil
       self.original_picture.stopped_at = Time.now
       raise ActiveRecord::Rollback unless self.original_picture.save
+      self.original_picture.resource_picture_pictures.each do |resource_picture_picture|
+        resource_picture_picture.resource_picture_id = nil
+        raise ActiveRecord::Rollback unless resource_picture_picture.save
+      end
       begin
         PictureIO.resource_picture_io.delete(self.filename) if PictureIO.resource_picture_io.exist?(self.filename)
         PictureIO.resource_picture_io.delete(self.filename, 'full') if PictureIO.resource_picture_io.exist?(self.filename, 'full')
@@ -207,6 +246,10 @@ class ResourcePicture < Peta::Content
     Base64.encode64(self.restore 'full')
   end
   
+  def new_template
+    "#{self.license_group_module_name.tableize}/attributes/new"
+  end
+  
   def credit_template
     "#{self.license_group_module_name.tableize}/attributes/credit"
   end
@@ -215,4 +258,13 @@ class ResourcePicture < Peta::Content
     "#{self.license_group_module_name.tableize}/attributes/full_credit"
   end
   
+  def self.remake_all
+    ResourcePicture.find_each do |resource_picture|
+      resource_picture.boosts 'post'
+      full = resource_picture.restore 'full'
+      imager = PettanImager.load full
+      resource_picture.store_picture_with_gif(imager)
+    end
+  end
+  
 end