globalize2 - create_translation_table! и варианты для столбцов - PullRequest
1 голос
/ 06 мая 2010

подскажите пожалуйста - как использовать метод create_translation_table! globalize2 с дополнительными параметрами, такими как: null => false,: default => "abc" ???

Ответы [ 2 ]

0 голосов
/ 06 мая 2010

Вот определение метода в текущей версии globalize2:

  def create_translation_table!(fields)
    translated_attribute_names.each do |f|
      raise MigrationMissingTranslatedField, "Missing translated field #{f}" unless fields[f]
    end

    fields.each do |name, type|
      if translated_attribute_names.include?(name) && ![:string, :text].include?(type)
        raise BadMigrationFieldType, "Bad field type for #{name}, should be :string or :text"
      end
    end

    self.connection.create_table(translation_table_name) do |t|
      t.references table_name.sub(/^#{table_name_prefix}/, "").singularize
      t.string :locale
      fields.each do |name, type|
        t.column name, type
      end
      t.timestamps
    end

    self.connection.add_index(
      translation_table_name, 
      "#{table_name.sub(/^#{table_name_prefix}/, "").singularize}_id",
      :name => translation_index_name
    )
  end

Как видите, третий параметр не передается в объявления t.column. Поэтому globalize2 не будет поддерживать это без патча.

Я предлагаю просто создать миграцию вручную.

0 голосов
/ 06 мая 2010

TRY Что-то вроде следующего

Post.create_translation_table! :title => :string, :text => :text, {:null=>false, :default=>"abc"}
...