From 75e109055cbf2a200c1995b1a0257578728a15a2 Mon Sep 17 00:00:00 2001 From: Thomas von Deyen Date: Thu, 14 Mar 2024 21:56:05 +0100 Subject: [PATCH] Add multi language image descriptions --- .../alchemy/alchemy.image_overlay.coffee | 3 +- app/assets/stylesheets/alchemy/forms.scss | 6 ++++ .../alchemy/admin/ingredients_controller.rb | 1 + .../alchemy/admin/pages_controller.rb | 1 + .../admin/picture_descriptions_controller.rb | 15 +++++++++ .../alchemy/admin/pictures_controller.rb | 19 ++++++++++- app/models/alchemy/ingredients/picture.rb | 6 ++-- app/models/alchemy/picture.rb | 8 +++++ app/models/alchemy/picture_description.rb | 8 +++++ .../ingredients/_picture_fields.html.erb | 2 +- .../admin/picture_descriptions/_form.html.erb | 11 +++++++ .../admin/picture_descriptions/edit.html.erb | 6 ++++ .../_picture_description_field.html.erb | 30 ++++++++++++++++- .../shared/_picture_tools.html.erb | 2 +- config/locales/alchemy.en.yml | 5 +++ config/routes.rb | 2 ++ ...240208101342_add_description_to_picture.rb | 5 --- ...244_create_alchemy_picture_descriptions.rb | 11 +++++++ lib/alchemy/permissions.rb | 1 + .../alchemy/admin/pictures_controller_spec.rb | 17 ++++++++-- spec/dummy/config/locales/alchemy.de.yml | 5 +++ ...240208101342_add_description_to_picture.rb | 5 --- ...te_alchemy_picture_descriptions.alchemy.rb | 12 +++++++ spec/dummy/db/schema.rb | 17 ++++++++-- .../admin/picture_library_integration_spec.rb | 32 +++++++++++++++++++ .../alchemy/ingredients/picture_spec.rb | 25 +++++++++++---- .../alchemy/picture_description_spec.rb | 19 +++++++++++ spec/models/alchemy/picture_spec.rb | 23 +++++++++++++ .../alchemy/admin/pictures_controller_spec.rb | 1 + spec/views/admin/pictures/show_spec.rb | 11 +++++++ 30 files changed, 280 insertions(+), 29 deletions(-) create mode 100644 app/controllers/alchemy/admin/picture_descriptions_controller.rb create mode 100644 app/models/alchemy/picture_description.rb create mode 100644 app/views/alchemy/admin/picture_descriptions/_form.html.erb create mode 100644 app/views/alchemy/admin/picture_descriptions/edit.html.erb delete mode 100644 db/migrate/20240208101342_add_description_to_picture.rb create mode 100644 db/migrate/20240314105244_create_alchemy_picture_descriptions.rb delete mode 100644 spec/dummy/db/migrate/20240208101342_add_description_to_picture.rb create mode 100644 spec/dummy/db/migrate/20240411155901_create_alchemy_picture_descriptions.alchemy.rb create mode 100644 spec/models/alchemy/picture_description_spec.rb diff --git a/app/assets/javascripts/alchemy/alchemy.image_overlay.coffee b/app/assets/javascripts/alchemy/alchemy.image_overlay.coffee index a354f378c9..38b0fa3b68 100644 --- a/app/assets/javascripts/alchemy/alchemy.image_overlay.coffee +++ b/app/assets/javascripts/alchemy/alchemy.image_overlay.coffee @@ -17,7 +17,8 @@ class window.Alchemy.ImageOverlay extends Alchemy.Dialog @$previous = $('.previous-picture') @$next = $('.next-picture') @$document.keydown (e) => - return true if e.target.nodeName == 'INPUT' + if e.target.nodeName == 'INPUT' || e.target.nodeName == 'TEXTAREA' + return true switch e.which when 37 @previous() diff --git a/app/assets/stylesheets/alchemy/forms.scss b/app/assets/stylesheets/alchemy/forms.scss index ae294f1661..ab3f88570a 100644 --- a/app/assets/stylesheets/alchemy/forms.scss +++ b/app/assets/stylesheets/alchemy/forms.scss @@ -19,6 +19,12 @@ form { @include form-label; } + .inline-label { + display: inline-flex; + align-items: center; + gap: var(--spacing-1); + } + .input { padding: $default-padding 0; @include clearfix; diff --git a/app/controllers/alchemy/admin/ingredients_controller.rb b/app/controllers/alchemy/admin/ingredients_controller.rb index 936e9ec7ae..976d19ab03 100644 --- a/app/controllers/alchemy/admin/ingredients_controller.rb +++ b/app/controllers/alchemy/admin/ingredients_controller.rb @@ -10,6 +10,7 @@ class IngredientsController < Alchemy::Admin::BaseController helper "Alchemy::Admin::Ingredients" def edit + @language = Alchemy::Language.find(params[:language_id]) end def update diff --git a/app/controllers/alchemy/admin/pages_controller.rb b/app/controllers/alchemy/admin/pages_controller.rb index 2775aa6632..7726415000 100644 --- a/app/controllers/alchemy/admin/pages_controller.rb +++ b/app/controllers/alchemy/admin/pages_controller.rb @@ -114,6 +114,7 @@ def edit end @preview_url = @preview_urls.first.last @layoutpage = @page.layoutpage? + Alchemy::Current.language = @page.language end # Set page configuration like page names, meta tags and states. diff --git a/app/controllers/alchemy/admin/picture_descriptions_controller.rb b/app/controllers/alchemy/admin/picture_descriptions_controller.rb new file mode 100644 index 0000000000..72da21fe6f --- /dev/null +++ b/app/controllers/alchemy/admin/picture_descriptions_controller.rb @@ -0,0 +1,15 @@ +module Alchemy + module Admin + class PictureDescriptionsController < Alchemy::Admin::ResourcesController + def edit + @picture_description = @picture.descriptions.find_or_initialize_by(language_id: params[:language_id]) + end + + private + + def load_resource + @picture = Alchemy::Picture.find(params[:picture_id]) + end + end + end +end diff --git a/app/controllers/alchemy/admin/pictures_controller.rb b/app/controllers/alchemy/admin/pictures_controller.rb index 8c6d7f73cb..d2ca7ed0e8 100644 --- a/app/controllers/alchemy/admin/pictures_controller.rb +++ b/app/controllers/alchemy/admin/pictures_controller.rb @@ -5,6 +5,7 @@ module Admin class PicturesController < Alchemy::Admin::ResourcesController include UploaderResponses include ArchiveOverlay + include CurrentLanguage helper "alchemy/admin/tags" @@ -33,6 +34,9 @@ def show @previous = filtered_pictures.where("name < ?", @picture.name).last @next = filtered_pictures.where("name > ?", @picture.name).first @assignments = @picture.picture_ingredients.joins(element: :page) + @picture_description = @picture.descriptions.find_or_initialize_by( + language_id: Alchemy::Current.language.id + ) render action: "show" end @@ -193,7 +197,20 @@ def search_filter_params end def picture_params - params.require(:picture).permit(:image_file, :upload_hash, :name, :description, :tag_list) + params.require(:picture).permit( + :image_file, + :upload_hash, + :name, + { + descriptions_attributes: [ + :id, + :text, + :language_id, + :picture_id + ] + }, + :tag_list + ) end def picture_url_params diff --git a/app/models/alchemy/ingredients/picture.rb b/app/models/alchemy/ingredients/picture.rb index 54d76bae6a..a98da5cdbd 100644 --- a/app/models/alchemy/ingredients/picture.rb +++ b/app/models/alchemy/ingredients/picture.rb @@ -38,8 +38,10 @@ class Picture < Alchemy::Ingredient upsample ] - def alt_text - alt_tag.presence || picture&.description || picture&.name&.humanize + def alt_text(language: Alchemy::Current.language) + alt_tag.presence || + picture&.description_for(language) || + picture&.name&.humanize end # The first 30 characters of the pictures name diff --git a/app/models/alchemy/picture.rb b/app/models/alchemy/picture.rb index 837e70d686..a8c58c6967 100644 --- a/app/models/alchemy/picture.rb +++ b/app/models/alchemy/picture.rb @@ -55,6 +55,9 @@ class Picture < BaseRecord has_many :elements, through: :picture_ingredients has_many :pages, through: :elements has_many :thumbs, class_name: "Alchemy::PictureThumb", dependent: :destroy + has_many :descriptions, class_name: "Alchemy::PictureDescription", dependent: :destroy + + accepts_nested_attributes_for :descriptions, allow_destroy: true, reject_if: ->(attr) { attr[:text].blank? } # Raise error, if picture is in use (aka. assigned to an Picture ingredient) # @@ -231,6 +234,11 @@ def to_jq_upload } end + # Returns the picture description for a given language. + def description_for(language) + descriptions.find_by(language: language)&.text + end + # Returns an uri escaped name. # def urlname diff --git a/app/models/alchemy/picture_description.rb b/app/models/alchemy/picture_description.rb new file mode 100644 index 0000000000..4d4c0eef75 --- /dev/null +++ b/app/models/alchemy/picture_description.rb @@ -0,0 +1,8 @@ +module Alchemy + class PictureDescription < ActiveRecord::Base + belongs_to :picture, class_name: "Alchemy::Picture" + belongs_to :language, class_name: "Alchemy::Language" + + validates_uniqueness_of :picture_id, scope: :language_id + end +end diff --git a/app/views/alchemy/admin/ingredients/_picture_fields.html.erb b/app/views/alchemy/admin/ingredients/_picture_fields.html.erb index f1278d769a..48de6d06a7 100644 --- a/app/views/alchemy/admin/ingredients/_picture_fields.html.erb +++ b/app/views/alchemy/admin/ingredients/_picture_fields.html.erb @@ -1,6 +1,6 @@ <%= f.input :caption, as: ingredient.settings[:caption_as_textarea] ? 'text' : 'string' %> <%= f.input :title %> -<%= f.input :alt_tag, as: :text, placeholder: ingredient.alt_text %> +<%= f.input :alt_tag, as: :text, placeholder: ingredient.alt_text(language: @language) %> <%- if ingredient.settings[:sizes].present? && ingredient.settings[:srcset].blank? -%> <%= f.input :render_size, collection: [ diff --git a/app/views/alchemy/admin/picture_descriptions/_form.html.erb b/app/views/alchemy/admin/picture_descriptions/_form.html.erb new file mode 100644 index 0000000000..cb9d6d5b92 --- /dev/null +++ b/app/views/alchemy/admin/picture_descriptions/_form.html.erb @@ -0,0 +1,11 @@ +<% field_name_prefix = "picture[descriptions_attributes][#{picture_description_counter}]" %> + +<% if picture_description.persisted? %> + <%= hidden_field field_name_prefix, :id, value: picture_description.id %> +<% else %> + <%= hidden_field field_name_prefix, :language_id, value: picture_description.language_id %> + <%= hidden_field field_name_prefix, :picture_id, value: picture_description.picture_id %> +<% end %> + +<%= label field_name_prefix, :text, Alchemy::PictureDescription.human_attribute_name(:text), class: "control-label" %> +<%= text_area field_name_prefix, :text, value: picture_description.text, rows: 3 %> diff --git a/app/views/alchemy/admin/picture_descriptions/edit.html.erb b/app/views/alchemy/admin/picture_descriptions/edit.html.erb new file mode 100644 index 0000000000..b9707864f8 --- /dev/null +++ b/app/views/alchemy/admin/picture_descriptions/edit.html.erb @@ -0,0 +1,6 @@ + + <%= render "form", { + picture_description: @picture_description, + picture_description_counter: @picture.descriptions.index(@picture_description) + } %> + diff --git a/app/views/alchemy/admin/pictures/_picture_description_field.html.erb b/app/views/alchemy/admin/pictures/_picture_description_field.html.erb index 33b0d5813f..eefebf52bb 100644 --- a/app/views/alchemy/admin/pictures/_picture_description_field.html.erb +++ b/app/views/alchemy/admin/pictures/_picture_description_field.html.erb @@ -1 +1,29 @@ -<%= f.input :description %> \ No newline at end of file +
+ <% if Alchemy::Language.many? %> + + <% end %> + + + <%= render "alchemy/admin/picture_descriptions/form", + picture_description_counter: @picture.descriptions.index(@picture_description), + picture_description: @picture_description %> + +
+ + diff --git a/app/views/alchemy/ingredients/shared/_picture_tools.html.erb b/app/views/alchemy/ingredients/shared/_picture_tools.html.erb index 2e7f3871be..7b6bed3e6a 100644 --- a/app/views/alchemy/ingredients/shared/_picture_tools.html.erb +++ b/app/views/alchemy/ingredients/shared/_picture_tools.html.erb @@ -41,7 +41,7 @@ <%= content_tag "sl-tooltip", content: Alchemy.t(:edit_image_properties), placement: "top-end" do %> <%= link_to_dialog render_icon(:edit), - alchemy.edit_admin_ingredient_path(id: picture_editor.id), + alchemy.edit_admin_ingredient_path(id: picture_editor.id, language_id: @page.language_id), { title: Alchemy.t(:edit_image_properties), size: "380x255" diff --git a/config/locales/alchemy.en.yml b/config/locales/alchemy.en.yml index 030827b9f7..5b551ec2a4 100644 --- a/config/locales/alchemy.en.yml +++ b/config/locales/alchemy.en.yml @@ -812,6 +812,9 @@ en: alchemy/picture: one: Picture other: Pictures + alchemy/picture_description: + one: Picture Description + other: Picture Descriptions alchemy/user: one: User other: User @@ -902,6 +905,8 @@ en: image_file_size: "Filesize" name: "Name" tag_list: Tags + alchemy/picture_description: + text: "Description" alchemy/site: name: "Name" host: "Primary Host" diff --git a/config/routes.rb b/config/routes.rb index 56fce05faf..3f25a5bb66 100644 --- a/config/routes.rb +++ b/config/routes.rb @@ -64,6 +64,8 @@ end end + resources :picture_descriptions, only: [:index, :edit] + resources :attachments, except: [:new] do member do get :download diff --git a/db/migrate/20240208101342_add_description_to_picture.rb b/db/migrate/20240208101342_add_description_to_picture.rb deleted file mode 100644 index 4de6a0d912..0000000000 --- a/db/migrate/20240208101342_add_description_to_picture.rb +++ /dev/null @@ -1,5 +0,0 @@ -class AddDescriptionToPicture < ActiveRecord::Migration[7.0] - def change - add_column :alchemy_pictures, :description, :text - end -end diff --git a/db/migrate/20240314105244_create_alchemy_picture_descriptions.rb b/db/migrate/20240314105244_create_alchemy_picture_descriptions.rb new file mode 100644 index 0000000000..8c050d207e --- /dev/null +++ b/db/migrate/20240314105244_create_alchemy_picture_descriptions.rb @@ -0,0 +1,11 @@ +class CreateAlchemyPictureDescriptions < ActiveRecord::Migration[7.0] + def change + create_table :alchemy_picture_descriptions do |t| + t.belongs_to :picture, null: false, foreign_key: {to_table: :alchemy_pictures} + t.belongs_to :language, null: false, foreign_key: {to_table: :alchemy_languages} + t.text :text + + t.timestamps + end + end +end diff --git a/lib/alchemy/permissions.rb b/lib/alchemy/permissions.rb index d63e2caa52..fa92ea33a2 100644 --- a/lib/alchemy/permissions.rb +++ b/lib/alchemy/permissions.rb @@ -157,6 +157,7 @@ def alchemy_editor_rules end can :manage, Alchemy::Picture + can :manage, Alchemy::PictureDescription can :manage, Alchemy::Attachment can :manage, Alchemy::Tag can :index, Alchemy::Language diff --git a/spec/controllers/alchemy/admin/pictures_controller_spec.rb b/spec/controllers/alchemy/admin/pictures_controller_spec.rb index 7077a28560..864825556c 100644 --- a/spec/controllers/alchemy/admin/pictures_controller_spec.rb +++ b/spec/controllers/alchemy/admin/pictures_controller_spec.rb @@ -26,6 +26,8 @@ module Alchemy authorize_user(:as_admin) end + let!(:language) { create(:alchemy_language) } + describe "#index" do context "with search params" do let!(:picture_1) { create(:alchemy_picture, name: "cute kitten") } @@ -250,12 +252,23 @@ module Alchemy let(:picture) { create(:alchemy_picture) } subject do - put :update, params: {id: 1, picture: {name: "", description: "foo bar"}}, xhr: true + put :update, params: { + id: 1, + picture: { + name: "", + descriptions_attributes: { + 0 => { + text: "foo bar", + language_id: language.id + } + } + } + }, xhr: true end it "sets the description" do subject - expect(picture.description).to eq("foo bar") + expect(picture.description_for(language)).to eq("foo bar") end end end diff --git a/spec/dummy/config/locales/alchemy.de.yml b/spec/dummy/config/locales/alchemy.de.yml index 9e709137a7..c00c9433a6 100644 --- a/spec/dummy/config/locales/alchemy.de.yml +++ b/spec/dummy/config/locales/alchemy.de.yml @@ -22,3 +22,8 @@ de: richtext: Dieser Inhaltstyp stellt formatierbaren Text dar select: Dieser Inhaltstyp stellt Werte dar aus denen der Redakteur wählen kann text: Dieser Inhaltstyp stellt eine einfache Zeile Text dar + + activerecord: + attributes: + alchemy/picture_description: + text: "Bildbeschreibung" diff --git a/spec/dummy/db/migrate/20240208101342_add_description_to_picture.rb b/spec/dummy/db/migrate/20240208101342_add_description_to_picture.rb deleted file mode 100644 index 4de6a0d912..0000000000 --- a/spec/dummy/db/migrate/20240208101342_add_description_to_picture.rb +++ /dev/null @@ -1,5 +0,0 @@ -class AddDescriptionToPicture < ActiveRecord::Migration[7.0] - def change - add_column :alchemy_pictures, :description, :text - end -end diff --git a/spec/dummy/db/migrate/20240411155901_create_alchemy_picture_descriptions.alchemy.rb b/spec/dummy/db/migrate/20240411155901_create_alchemy_picture_descriptions.alchemy.rb new file mode 100644 index 0000000000..523a605076 --- /dev/null +++ b/spec/dummy/db/migrate/20240411155901_create_alchemy_picture_descriptions.alchemy.rb @@ -0,0 +1,12 @@ +# This migration comes from alchemy (originally 20240314105244) +class CreateAlchemyPictureDescriptions < ActiveRecord::Migration[7.0] + def change + create_table :alchemy_picture_descriptions do |t| + t.belongs_to :picture, null: false, foreign_key: {to_table: :alchemy_pictures} + t.belongs_to :language, null: false, foreign_key: {to_table: :alchemy_languages} + t.text :text + + t.timestamps + end + end +end diff --git a/spec/dummy/db/schema.rb b/spec/dummy/db/schema.rb index a1b1144551..0583e44cb9 100644 --- a/spec/dummy/db/schema.rb +++ b/spec/dummy/db/schema.rb @@ -10,7 +10,7 @@ # # It's strongly recommended that you check this file into your version control system. -ActiveRecord::Schema[7.1].define(version: 2024_02_08_101342) do +ActiveRecord::Schema[7.1].define(version: 2024_04_11_155901) do create_table "alchemy_attachments", force: :cascade do |t| t.string "name" t.string "file_name" @@ -136,7 +136,7 @@ create_table "alchemy_page_mutexes", force: :cascade do |t| t.integer "page_id", null: false - t.datetime "created_at" + t.datetime "created_at", precision: nil t.index ["page_id"], name: "index_alchemy_page_mutexes_on_page_id", unique: true end @@ -186,6 +186,16 @@ t.index ["urlname"], name: "index_pages_on_urlname" end + create_table "alchemy_picture_descriptions", force: :cascade do |t| + t.integer "picture_id", null: false + t.integer "language_id", null: false + t.text "text" + t.datetime "created_at", null: false + t.datetime "updated_at", null: false + t.index ["language_id"], name: "index_alchemy_picture_descriptions_on_language_id" + t.index ["picture_id"], name: "index_alchemy_picture_descriptions_on_picture_id" + end + create_table "alchemy_picture_thumbs", force: :cascade do |t| t.integer "picture_id", null: false t.string "signature", null: false @@ -207,7 +217,6 @@ t.string "image_file_uid" t.integer "image_file_size" t.string "image_file_format" - t.text "description" t.index ["creator_id"], name: "index_alchemy_pictures_on_creator_id" t.index ["image_file_name"], name: "index_alchemy_pictures_on_image_file_name" t.index ["name"], name: "index_alchemy_pictures_on_name" @@ -293,5 +302,7 @@ add_foreign_key "alchemy_page_mutexes", "alchemy_pages", column: "page_id" add_foreign_key "alchemy_page_versions", "alchemy_pages", column: "page_id", on_delete: :cascade add_foreign_key "alchemy_pages", "alchemy_languages", column: "language_id" + add_foreign_key "alchemy_picture_descriptions", "alchemy_languages", column: "language_id" + add_foreign_key "alchemy_picture_descriptions", "alchemy_pictures", column: "picture_id" add_foreign_key "alchemy_picture_thumbs", "alchemy_pictures", column: "picture_id" end diff --git a/spec/features/admin/picture_library_integration_spec.rb b/spec/features/admin/picture_library_integration_spec.rb index 262e312cd3..ba8b0c90b2 100644 --- a/spec/features/admin/picture_library_integration_spec.rb +++ b/spec/features/admin/picture_library_integration_spec.rb @@ -7,6 +7,8 @@ authorize_user(:as_admin) end + let!(:language) { create(:alchemy_language) } + describe "Tagging" do let!(:picture_1) { create(:alchemy_picture, tag_list: "tag1", name: "TaggedWith1") } let!(:picture_2) { create(:alchemy_picture, tag_list: "tag2", name: "TaggedWith2") } @@ -61,4 +63,34 @@ expect(page).to have_content("bla") end end + + describe "Picture descriptions" do + let!(:picture) { create(:alchemy_picture) } + + scenario "allows to add a picture description", :js do + visit alchemy.admin_pictures_path + page.find("a.thumbnail_background").click + expect(page).to have_field("Description") + fill_in "Description", with: "This is an amazing image." + click_button "Save" + within "#flash_notices" do + expect(page).to have_content("Picture updated successfully") + end + expect(picture.description_for(language)).to eq("This is an amazing image.") + end + + scenario "allows to add multi language picture descriptions", :js do + german = create(:alchemy_language, :german) + visit alchemy.admin_pictures_path + page.find("a.thumbnail_background").click + expect(page).to have_field("Description") + select(german.language_code.upcase, from: "Language") + fill_in "Description", with: "Tolles Bild." + click_button "Save" + within "#flash_notices" do + expect(page).to have_content("Picture updated successfully") + end + expect(picture.description_for(german)).to eq("Tolles Bild.") + end + end end diff --git a/spec/models/alchemy/ingredients/picture_spec.rb b/spec/models/alchemy/ingredients/picture_spec.rb index aa037b4555..23256b78c5 100644 --- a/spec/models/alchemy/ingredients/picture_spec.rb +++ b/spec/models/alchemy/ingredients/picture_spec.rb @@ -34,14 +34,19 @@ end context "with a picture description" do - before { picture.description = "Another cute kitten" } - - it { is_expected.to eq("Another cute kitten") } + it "returns picture description" do + expect(picture).to receive(:description_for) { + "Another cute kitten" + } + is_expected.to eq("Another cute kitten") + end context "with a alt_tag" do before { picture_ingredient.alt_tag = "A cute kitten" } - it { is_expected.to eq("A cute kitten") } + it "returns alt text" do + is_expected.to eq("A cute kitten") + end end end @@ -50,10 +55,16 @@ it { is_expected.to eq("Cute kitten") } - context "with a picture description" do - before { picture.description = "Another cute kitten" } + context "with a picture description for current language" do + before do + expect(picture).to receive(:description_for) { + "Another cute kitten" + } + end - it { is_expected.to eq("Another cute kitten") } + it "returns the picture description" do + is_expected.to eq("Another cute kitten") + end end end end diff --git a/spec/models/alchemy/picture_description_spec.rb b/spec/models/alchemy/picture_description_spec.rb new file mode 100644 index 0000000000..3002f6df7f --- /dev/null +++ b/spec/models/alchemy/picture_description_spec.rb @@ -0,0 +1,19 @@ +# frozen_string_literal: true + +require "rails_helper" + +RSpec.describe Alchemy::PictureDescription do + it { should belong_to(:picture).class_name("Alchemy::Picture") } + it { should belong_to(:language).class_name("Alchemy::Language") } + + describe "validations" do + let(:picture) { create(:alchemy_picture) } + let(:language) { create(:alchemy_language) } + + let!(:description) do + described_class.create!(picture: picture, language: language, text: "Test description") + end + + it { should validate_uniqueness_of(:picture_id).scoped_to(:language_id) } + end +end diff --git a/spec/models/alchemy/picture_spec.rb b/spec/models/alchemy/picture_spec.rb index 8ee9f7b6e9..478e756799 100644 --- a/spec/models/alchemy/picture_spec.rb +++ b/spec/models/alchemy/picture_spec.rb @@ -373,6 +373,29 @@ module Alchemy end end + describe "#description_for" do + subject { picture.description_for(language) } + + let(:picture) { create(:alchemy_picture) } + let(:language) { create(:alchemy_language) } + + context "with a description for the given language" do + let!(:description) do + Alchemy::PictureDescription.create!( + picture: picture, + language: language, + text: "A nice picture" + ) + end + + it { is_expected.to eq(description.text) } + end + + context "without a description for the given language" do + it { is_expected.to be_nil } + end + end + describe "#to_jq_upload" do subject { picture.to_jq_upload } diff --git a/spec/requests/alchemy/admin/pictures_controller_spec.rb b/spec/requests/alchemy/admin/pictures_controller_spec.rb index 2bb88a9d7a..663011eebe 100644 --- a/spec/requests/alchemy/admin/pictures_controller_spec.rb +++ b/spec/requests/alchemy/admin/pictures_controller_spec.rb @@ -16,6 +16,7 @@ context "as author" do before do authorize_user(:as_author) + create(:alchemy_language) end it "returns the url to picture" do diff --git a/spec/views/admin/pictures/show_spec.rb b/spec/views/admin/pictures/show_spec.rb index 60caee1bf6..9b5af7b2d0 100644 --- a/spec/views/admin/pictures/show_spec.rb +++ b/spec/views/admin/pictures/show_spec.rb @@ -18,6 +18,16 @@ }) end + let(:language) { create(:alchemy_language) } + + let(:picture_description) do + Alchemy::PictureDescription.create!( + picture: picture, + language: language, + text: "This is an amazing image." + ) + end + before do allow(view).to receive(:admin_picture_path).and_return("/path") allow(view).to receive(:edit_admin_page_path).and_return("/path") @@ -26,6 +36,7 @@ view.extend Alchemy::Admin::FormHelper view.extend Alchemy::BaseHelper assign(:picture, picture) + assign(:picture_description, picture_description) end it "displays picture in original format" do