removing asset_collections: script + remove references in liquid
This commit is contained in:
parent
58ab954ec1
commit
ecdb79bb2d
@ -1,21 +0,0 @@
|
||||
module Locomotive
|
||||
module Liquid
|
||||
module Drops
|
||||
class Asset < Base
|
||||
|
||||
def before_method(meth)
|
||||
return '' if @source.nil?
|
||||
|
||||
if not @@forbidden_attributes.include?(meth.to_s)
|
||||
value = @source.send(meth)
|
||||
end
|
||||
end
|
||||
|
||||
def url
|
||||
@source.source.url
|
||||
end
|
||||
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
@ -1,54 +1,14 @@
|
||||
require 'locomotive/liquid/drops/contents'
|
||||
|
||||
module Locomotive
|
||||
module Liquid
|
||||
module Drops
|
||||
|
||||
class AssetCollections < ::Liquid::Drop
|
||||
class AssetCollections < Contents
|
||||
|
||||
def before_method(meth)
|
||||
collection = @context.registers[:site].asset_collections.where(:slug => meth.to_s).first
|
||||
AssetCollectionProxy.new(collection)
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
class AssetCollectionProxy < ::Liquid::Drop
|
||||
|
||||
def initialize(collection)
|
||||
@collection = collection
|
||||
end
|
||||
|
||||
def first
|
||||
@collection.ordered_assets.first
|
||||
end
|
||||
|
||||
def last
|
||||
@collection.ordered_assets.last
|
||||
end
|
||||
|
||||
def each(&block)
|
||||
@collection.ordered_assets.each(&block)
|
||||
end
|
||||
|
||||
def paginate(options = {})
|
||||
paginated_collection = @collection.ordered_assets.paginate(options)
|
||||
{
|
||||
:collection => paginated_collection,
|
||||
:current_page => paginated_collection.current_page,
|
||||
:previous_page => paginated_collection.previous_page,
|
||||
:next_page => paginated_collection.next_page,
|
||||
:total_entries => paginated_collection.total_entries,
|
||||
:total_pages => paginated_collection.total_pages,
|
||||
:per_page => paginated_collection.per_page
|
||||
}
|
||||
end
|
||||
|
||||
def size
|
||||
@collection.assets.size
|
||||
end
|
||||
|
||||
def before_method(meth)
|
||||
return '' if @collection.nil?
|
||||
@collection.send(meth)
|
||||
Rails.logger.warn "\n[WARNING] asset_collections is deprecated and will be removed in the next commits. Please, use contents.<slug> instead.\n\n"
|
||||
super(meth)
|
||||
end
|
||||
|
||||
end
|
||||
|
@ -15,7 +15,7 @@ namespace :locomotive do
|
||||
|
||||
desc 'Remove asset collections and convert them into content types'
|
||||
task :remove_asset_collections => :environment do
|
||||
puts "asset_collection # ? #{AssetCollection.count}"
|
||||
puts "Processing #{AssetCollection.count} asset collection(s)..."
|
||||
|
||||
AssetCollection.all.each do |collection|
|
||||
site = Site.find(collection.attributes['site_id'])
|
||||
@ -23,55 +23,72 @@ namespace :locomotive do
|
||||
if collection.internal?
|
||||
# internal collection => create simple assets without associated to a collection
|
||||
|
||||
collection.assets.each do |tmp_asset|
|
||||
|
||||
sanitized_attributes = tmp_asset.attributes.dup
|
||||
sanitized_attributes.delete_if { |k, v| [:name, :source_filename].include?(k) }
|
||||
sanitized_attributes[:_id] = tmp_asset._id
|
||||
|
||||
asset = site.assets.build(sanitized_attributes)
|
||||
|
||||
asset.source = tmp_asset.source.file
|
||||
|
||||
asset.save!
|
||||
|
||||
puts "asset = #{asset.inspect}"
|
||||
|
||||
asset.destroy
|
||||
end
|
||||
# collection.assets.each do |tmp_asset|
|
||||
# puts "tmp asset = #{tmp_asset.inspect} / #{tmp_asset.source.url.inspect}"
|
||||
#
|
||||
# sanitized_attributes = tmp_asset.attributes.dup
|
||||
# # sanitized_attributes.delete_if { |k, v| [:name, :source_filename].include?(k) }
|
||||
# sanitized_attributes[:_id] = tmp_asset._id
|
||||
#
|
||||
# asset = site.assets.build(sanitized_attributes)
|
||||
#
|
||||
# # asset.source = tmp_asset.source.file
|
||||
#
|
||||
# asset.save!
|
||||
#
|
||||
# puts "asset = #{asset.inspect} / #{asset.source.url.inspect}"
|
||||
#
|
||||
# # asset.destroy
|
||||
# end
|
||||
else
|
||||
collection.fetch_asset_klass.class_eval { def self.model_name; 'Asset'; end }
|
||||
|
||||
# create content_types reflection of an asset collection
|
||||
ContentType.where(:slug => collection.slug).all.collect(&:destroy)
|
||||
|
||||
content_type = site.content_types.build({
|
||||
:name => collection.name,
|
||||
:slug => collection.slug,
|
||||
:order_by => 'manually'
|
||||
:order_by => '_position_in_list'
|
||||
})
|
||||
|
||||
# add default custom fields
|
||||
content_type.content_custom_fields.build(:label => 'Name', :slug => 'name', :kind => 'string', :required => true)
|
||||
content_type.content_custom_fields.build(:label => 'Source', :slug => 'source', :kind => 'file', :required => true)
|
||||
content_type._id = collection._id
|
||||
|
||||
# extra custom fields
|
||||
collection.asset_custom_fields.each do |field|
|
||||
content_type.content_custom_fields.build(field.attributes)
|
||||
collection.asset_custom_fields.each_with_index do |field, i|
|
||||
content_type.content_custom_fields.build(field.attributes.merge(:position => i + 3))
|
||||
end
|
||||
|
||||
# puts "new content_type = #{content_type.inspect}"
|
||||
# add default custom fields
|
||||
content_type.content_custom_fields.build(:label => 'Name', :_alias => 'name', :kind => 'string', :required => true, :position => 1)
|
||||
content_type.content_custom_fields.build(:label => 'Source', :_alias => 'source', :kind => 'file', :required => true, :position => 2)
|
||||
|
||||
# puts "valid ? #{content_type.valid?.inspect}"
|
||||
content_type.save!
|
||||
|
||||
content_type = ContentType.find(content_type._id) # hard reload
|
||||
|
||||
# set the highlighted field name
|
||||
field = content_type.content_custom_fields.detect { |f| f._alias == 'name' }
|
||||
content_type.highlighted_field_name = field._name
|
||||
content_type.save
|
||||
content_type = ContentType.find(content_type._id)
|
||||
|
||||
# puts "new content_type = #{content_type.inspect} /\n\n #{content_type.content_custom_fields.inspect}\n\n"
|
||||
# puts "collection asset name = #{collection.fetch_asset_klass.inspect}"
|
||||
|
||||
# insert data
|
||||
# puts "collection.assets = #{collection.ordered_assets.inspect} / #{collection.ordered_assets.class}"
|
||||
|
||||
collection.ordered_assets.each do |asset|
|
||||
attributes = (if asset.custom_fields.blank?
|
||||
{ :created_at => asset.created_at, :updated_at => asset.updated_at }
|
||||
else
|
||||
asset.aliased_attributes
|
||||
{}.tap do |h|
|
||||
asset.custom_fields.each do |field|
|
||||
case field.kind
|
||||
when 'file' then h["#{field._name}"] = asset.send("#{field._name}".to_sym)
|
||||
else
|
||||
h[field._alias] = asset.send(field._name.to_sym)
|
||||
end
|
||||
end
|
||||
end
|
||||
end)
|
||||
|
||||
attributes.merge!(:name => asset.name, :_position_in_list => asset.position)
|
||||
@ -80,14 +97,17 @@ namespace :locomotive do
|
||||
|
||||
content = content_type.contents.build(attributes)
|
||||
|
||||
content._id = asset._id
|
||||
|
||||
content.source = asset.source.file
|
||||
|
||||
content.save!
|
||||
content.save(:validate => false)
|
||||
|
||||
puts "content = #{content.inspect}"
|
||||
# puts "content = #{content.inspect} / #{content.source.url} / #{asset.source.url}"
|
||||
# puts "source (large) #{content.custom_field_9?} / #{content.custom_field_9.url} / #{asset.source.url}"
|
||||
# puts "custom_field_4 (thumb) #{content.custom_field_4?} / #{content.custom_field_4.url} / #{asset.custom_field_4.url}"
|
||||
# puts "====="
|
||||
end
|
||||
|
||||
content_type.destroy
|
||||
end
|
||||
end
|
||||
end
|
||||
@ -149,7 +169,5 @@ class TmpAsset
|
||||
field :position, :type => Integer, :default => 0
|
||||
mount_uploader :source, TmpAssetUploader
|
||||
embedded_in :collection, :class_name => 'AssetCollection', :inverse_of => :assets
|
||||
def site_id
|
||||
self.collection.site_id
|
||||
end
|
||||
def site_id; self.collection.site_id; end
|
||||
end
|
||||
|
Loading…
Reference in New Issue
Block a user