Feature #22482
closedRespond with "No preview available" instead of sending the file when no preview is available
0%
Description
For the sake of consistency, I think, that all file types should support "View" within the repository browser. Currently this is only done for images and smaller text files. For other files the View action is similar to Download. I think this behavior is confusing.
The attached patch series, adds this feature.
It does a couple of things:
0001-Add-basic-test-for-image-view-22058.patch
¶
Adds a test case for #22058 since I was working on this anyway. This patch is not essential in this series.
0002-Add-view-for-no-preview-repository-files.patch
¶
It changes RepositoriesController#entry_and_raw
so that a download is only triggered, when is_raw
is set. Otherwise it always falls back to rendering a template. This might be refactored lateron to remove entry_and_raw
all together since entry
and raw
don't share behavior anymore. To keep changes isolated I did not include this refactoring in this patch series.
It adds extends the entry.html.erb
to render the common/other
partial if the file does not match the expected file types or if it is to big for inline rendering.
It adds the common/other
partial which just renders a message "No preview available"
The private helper method is_entry_text_data?
was no longer used and has been removed.
0003-Show-attachment-view-even-is-no-preview-is-available.patch
¶
This change is not directly related to the repository browser. But I thought, it would make sense to also support show on all attachments and the change was simple enough.
The changes within the patch series also make integration of Redmine into other services easier, since the other service may safely link to the URL /attachments/:id
or /repository/revisions/:rev/entry/:file
and it will always behave similarly. Before this change, this URL would sometimes render an HTML page, sometimes it would send a file directly. A download can still be forced using the ../download/..
and ../raw/..
URLs.
Files
Related issues