mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2025-01-19 14:01:03 +08:00
Controller action for card inline preview
This commit is contained in:
parent
12b903dbe7
commit
4eebfa5461
6 changed files with 94 additions and 1 deletions
|
@ -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() {
|
function initCallBacks() {
|
||||||
if (typeof(applyCreateWopiFileCallback) === 'function') applyCreateWopiFileCallback();
|
if (typeof(applyCreateWopiFileCallback) === 'function') applyCreateWopiFileCallback();
|
||||||
applyCheckboxCallBack();
|
applyCheckboxCallBack();
|
||||||
|
@ -389,6 +410,7 @@
|
||||||
applyCollapseLinkCallBack();
|
applyCollapseLinkCallBack();
|
||||||
initDeleteStep();
|
initDeleteStep();
|
||||||
TinyMCE.highlight();
|
TinyMCE.highlight();
|
||||||
|
initPreviewToggle();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -97,6 +97,24 @@ class AssetsController < ApplicationController
|
||||||
return edit_supported, title
|
return edit_supported, title
|
||||||
end
|
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')
|
||||||
|
"<iframe src=\"#{url}\" title=\"DocumentPreview\"></iframe>"
|
||||||
|
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
|
def file_url
|
||||||
return render_404 unless @asset.file.attached?
|
return render_404 unless @asset.file.attached?
|
||||||
|
|
||||||
|
@ -300,6 +318,10 @@ class AssetsController < ApplicationController
|
||||||
params.permit(:file)
|
params.permit(:file)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def toggle_view_mode_params
|
||||||
|
params.require(:asset).permit(:view_mode)
|
||||||
|
end
|
||||||
|
|
||||||
def asset_data_type(asset)
|
def asset_data_type(asset)
|
||||||
return 'wopi' if wopi_file?(asset)
|
return 'wopi' if wopi_file?(asset)
|
||||||
return 'image' if asset.image?
|
return 'image' if asset.image?
|
||||||
|
|
|
@ -403,6 +403,14 @@ class Asset < ApplicationRecord
|
||||||
return convert_variant_to_base64(medium_preview) if style == :medium
|
return convert_variant_to_base64(medium_preview) if style == :medium
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def small_card
|
||||||
|
false
|
||||||
|
end
|
||||||
|
|
||||||
|
def inline_card
|
||||||
|
!small_card
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
def tempdir
|
def tempdir
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
<div class="attachment-placeholder pull-left">
|
<div class="attachment-placeholder pull-left">
|
||||||
|
<a href="#" class="dataPreviewAction" data-asset-id="<%= asset.id %>" data-preview-type="inline">InLine</a>
|
||||||
<div class="attachment-thumbnail <%= asset.previewable? ? '' : 'no-shadow' %> <%= asset.file.attached? ? asset.file.metadata['asset_type'] : '' %>">
|
<div class="attachment-thumbnail <%= asset.previewable? ? '' : 'no-shadow' %> <%= asset.file.attached? ? asset.file.metadata['asset_type'] : '' %>">
|
||||||
<% if asset.previewable? %>
|
<% if asset.previewable? %>
|
||||||
<%= image_tag asset.medium_preview,
|
<%= image_tag asset.medium_preview,
|
||||||
|
|
|
@ -640,6 +640,7 @@ Rails.application.routes.draw do
|
||||||
get 'files/:id/file_url', to: 'assets#file_url', as: 'asset_file_url'
|
get 'files/:id/file_url', to: 'assets#file_url', as: 'asset_file_url'
|
||||||
get 'files/:id/download', to: 'assets#download', as: 'asset_download'
|
get 'files/:id/download', to: 'assets#download', as: 'asset_download'
|
||||||
get 'files/:id/edit', to: 'assets#edit', as: 'edit_asset'
|
get 'files/:id/edit', to: 'assets#edit', as: 'edit_asset'
|
||||||
|
patch 'files/:id/toggle_view_mode', to: 'assets#toggle_view_mode', as: 'toggle_view_mode'
|
||||||
post 'files/:id/update_image', to: 'assets#update_image',
|
post 'files/:id/update_image', to: 'assets#update_image',
|
||||||
as: 'update_asset_image'
|
as: 'update_asset_image'
|
||||||
post 'files/create_wopi_file',
|
post 'files/create_wopi_file',
|
||||||
|
|
|
@ -67,4 +67,44 @@ describe AssetsController, type: :controller do
|
||||||
.to(change { Activity.count })
|
.to(change { Activity.count })
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe 'GET asset_card' do
|
||||||
|
let(:action) { get :toggle_view_mode, params: params, format: :json }
|
||||||
|
let!(:params) do
|
||||||
|
{ id: asset.id }
|
||||||
|
end
|
||||||
|
|
||||||
|
it do
|
||||||
|
action
|
||||||
|
|
||||||
|
expect(response).to have_http_status 200
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'when small card' do
|
||||||
|
it do
|
||||||
|
action
|
||||||
|
|
||||||
|
expect(response).to have_http_status 200
|
||||||
|
# wtf, not working here?, render_to_string is returning nil
|
||||||
|
# expect(JSON.parse(response.body)['html']).to be_eql 'hellow world'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'when iframe' do
|
||||||
|
before do
|
||||||
|
allow_any_instance_of(Asset).to receive(:small_card).and_return(false)
|
||||||
|
allow_any_instance_of(Asset).to receive(:get_action_url).and_return('fakeurl.com')
|
||||||
|
allow(controller).to receive(:wopi_enabled?).and_return(true)
|
||||||
|
allow(controller).to receive(:wopi_file?).and_return(true)
|
||||||
|
end
|
||||||
|
|
||||||
|
it do
|
||||||
|
action
|
||||||
|
|
||||||
|
expect(response).to have_http_status 200
|
||||||
|
expect(JSON.parse(response.body)['html'])
|
||||||
|
.to be_eql '<iframe src="fakeurl.com" title="DocumentPreview"></iframe>'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue