diff --git a/app/assets/javascripts/protocols/steps.js.erb b/app/assets/javascripts/protocols/steps.js.erb index 8f96b177b..c9dbcd9e2 100644 --- a/app/assets/javascripts/protocols/steps.js.erb +++ b/app/assets/javascripts/protocols/steps.js.erb @@ -380,6 +380,27 @@ }); } + function initPreviewToggle(){ + $('.attachment-placeholder').on('click', '.dataPreviewAction', function (e) { + var view_mode = $(this).data('preview-type'); + var asset_id = $(this).data('asset-id'); + e.preventDefault(); + + $.ajax({ + url: `/files/${asset_id}/toggle_view_mode`, + type: "PATCH", + dataType: "json", + data: { asset: { view_mode: view_mode }}, + success: function (data) { + console.log(data); + }, + error: function (data) { + console.log(data); + } + }); + }); + } + function initCallBacks() { if (typeof(applyCreateWopiFileCallback) === 'function') applyCreateWopiFileCallback(); applyCheckboxCallBack(); @@ -389,6 +410,7 @@ applyCollapseLinkCallBack(); initDeleteStep(); TinyMCE.highlight(); + initPreviewToggle(); } /* diff --git a/app/controllers/assets_controller.rb b/app/controllers/assets_controller.rb index ba7a45ffe..e8dab1b70 100644 --- a/app/controllers/assets_controller.rb +++ b/app/controllers/assets_controller.rb @@ -97,6 +97,24 @@ class AssetsController < ApplicationController return edit_supported, title end + def toggle_view_mode + # view_mode: card / inline + # @asset.update!(view_mode: toggle_view_mode_params[:view_mode]) + + html = if @asset.inline_card && wopi_enabled? && wopi_file?(@asset) + url = @asset.get_action_url(current_user, 'embedview') + "" + else + render_to_string(partial: 'shared/asset_placeholder.html.erb', locals: { asset: @asset, edit_page: false }) + end + + respond_to do |format| + format.json do + render json: { html: html }, status: :ok + end + end + end + def file_url return render_404 unless @asset.file.attached? @@ -300,6 +318,10 @@ class AssetsController < ApplicationController params.permit(:file) end + def toggle_view_mode_params + params.require(:asset).permit(:view_mode) + end + def asset_data_type(asset) return 'wopi' if wopi_file?(asset) return 'image' if asset.image? diff --git a/app/models/asset.rb b/app/models/asset.rb index f6ec993ec..887268fa7 100644 --- a/app/models/asset.rb +++ b/app/models/asset.rb @@ -403,6 +403,14 @@ class Asset < ApplicationRecord return convert_variant_to_base64(medium_preview) if style == :medium end + def small_card + false + end + + def inline_card + !small_card + end + private def tempdir diff --git a/app/views/shared/_asset_placeholder.html.erb b/app/views/shared/_asset_placeholder.html.erb index a9b2ace1d..34bf8544a 100644 --- a/app/views/shared/_asset_placeholder.html.erb +++ b/app/views/shared/_asset_placeholder.html.erb @@ -1,5 +1,5 @@