diff --git a/app/helpers/globalize_helper.rb b/app/helpers/globalize_helper.rb index b64c1ff09..fac263a1b 100644 --- a/app/helpers/globalize_helper.rb +++ b/app/helpers/globalize_helper.rb @@ -14,6 +14,18 @@ module GlobalizeHelper same_locale?(neutral_locale(I18n.locale), neutral_locale(locale)) ? "" : "display: none" end + def render_translations_to_delete(resource) + capture do + resource.globalize_locales.each do |locale| + concat translation_enabled_tag(locale, enable_locale?(resource, locale)) + end + end + end + + def translation_enabled_tag(locale, enabled) + hidden_field_tag("enabled_translations[#{locale}]", (enabled ? 1 : 0)) + end + def css_to_display_translation?(resource, locale) resource.translated_locales.include?(neutral_locale(locale)) || locale == I18n.locale ? "" : "display: none" end diff --git a/app/helpers/site_customization_helper.rb b/app/helpers/site_customization_helper.rb index d9318fd9b..9e54fbf4e 100644 --- a/app/helpers/site_customization_helper.rb +++ b/app/helpers/site_customization_helper.rb @@ -1,5 +1,9 @@ module SiteCustomizationHelper + def site_customization_enable_translation?(locale) + I18nContentTranslation.existing_languages.include?(neutral_locale(locale)) || locale == I18n.locale + end + def site_customization_display_translation?(locale) - I18nContentTranslation.existing_languages.include?(neutral_locale(locale)) || locale == I18n.locale ? "" : "display: none" + site_customization_enable_translation?(locale) ? "" : "display: none" end end diff --git a/app/views/admin/banners/_form.html.erb b/app/views/admin/banners/_form.html.erb index 495cc5e8a..105a872fb 100644 --- a/app/views/admin/banners/_form.html.erb +++ b/app/views/admin/banners/_form.html.erb @@ -4,9 +4,7 @@ <%= render 'errors' %> - <% @banner.globalize_locales.each do |locale| %> - <%= hidden_field_tag "delete_translations[#{locale}]", 0 %> - <% end %> + <%= render_translations_to_delete(@banner) %>