summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLukas Reschke <lukas@owncloud.com>2015-05-04 11:44:51 +0200
committerLukas Reschke <lukas@owncloud.com>2015-05-04 11:44:51 +0200
commit17fedc80dac7acd3d85f1f132455e94d4fd920c6 (patch)
tree7e99e5d91615fd388a390c8c11b6b54589a5d1d6
parent0f7b8dd33814a036b98727a7a9d82deaae061785 (diff)
parent0729fc2fbc46880901c0bbbab7985b0a14fb2a03 (diff)
downloadnextcloud-server-17fedc80dac7acd3d85f1f132455e94d4fd920c6.tar.gz
nextcloud-server-17fedc80dac7acd3d85f1f132455e94d4fd920c6.zip
Merge pull request #15652 from oparoz/better-text-previews
Show a text preview instead of a bitmap preview of text
-rw-r--r--apps/files_sharing/css/public.css22
-rw-r--r--apps/files_sharing/js/public.js51
2 files changed, 60 insertions, 13 deletions
diff --git a/apps/files_sharing/css/public.css b/apps/files_sharing/css/public.css
index ef013ca07d7..fc78ced0b76 100644
--- a/apps/files_sharing/css/public.css
+++ b/apps/files_sharing/css/public.css
@@ -2,7 +2,6 @@
background: #fff;
text-align: center;
margin: 45px auto 0;
- min-height: 600px;
}
#preview .notCreatable {
@@ -28,6 +27,27 @@
max-width:100%;
}
+#imgframe .text-preview {
+ display: inline-block;
+ position: relative;
+ text-align: left;
+ white-space: pre-wrap;
+ overflow-y: hidden;
+ height: auto;
+ min-height: 200px;
+ max-height: 800px;
+ -webkit-touch-callout: none;
+ -webkit-user-select: none;
+ -khtml-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+}
+
+#imgframe .ellipsis {
+ font-size: 1.2em;
+}
+
/* fix multiselect bar offset on shared page */
thead {
left: 0 !important;
diff --git a/apps/files_sharing/js/public.js b/apps/files_sharing/js/public.js
index 41bfeba031f..79bd0bb0c47 100644
--- a/apps/files_sharing/js/public.js
+++ b/apps/files_sharing/js/public.js
@@ -87,12 +87,17 @@ OCA.Sharing.PublicApp = {
// dynamically load image previews
+ var token = $('#sharingToken').val();
+ var bottomMargin = 350;
+ var previewWidth = $(window).width() * window.devicePixelRatio;
+ var previewHeight = $(window).height() - bottomMargin * window.devicePixelRatio;
+ previewHeight = Math.max(200, previewHeight);
var params = {
- x: $(document).width() * window.devicePixelRatio,
- y: $(document).height() * window.devicePixelRatio,
+ x: previewWidth,
+ y: previewHeight,
a: 'true',
file: encodeURIComponent(this.initialDir + $('#filename').val()),
- t: $('#sharingToken').val(),
+ t: token,
scalingup: 0
};
@@ -105,6 +110,18 @@ OCA.Sharing.PublicApp = {
(maxGifSize === -1 || fileSize <= (maxGifSize * 1024 * 1024))) {
img.attr('src', $('#downloadURL').val());
img.appendTo('#imgframe');
+ } else if (mimetype.substr(0, mimetype.indexOf('/')) === 'text') {
+ // Undocumented Url to public WebDAV endpoint
+ var url = parent.location.protocol + '//' + location.host + OC.linkTo('', 'public.php/webdav');
+ $.ajax({
+ url: url,
+ headers: {
+ Authorization: 'Basic ' + btoa(token + ':'),
+ Range: 'bytes=0-1000'
+ }
+ }).then(function (data) {
+ self._showTextPreview(data, previewHeight);
+ });
} else if (previewSupported === 'true' ||
mimetype.substr(0, mimetype.indexOf('/')) === 'image' &&
mimetype !== 'image/svg+xml') {
@@ -123,26 +140,21 @@ OCA.Sharing.PublicApp = {
filename = JSON.stringify(filename);
}
var path = dir || FileList.getCurrentDirectory();
- var token = $('#sharingToken').val();
var params = {
path: path,
files: filename
};
- return OC.generateUrl('/s/'+token+'/download') + '?' + OC.buildQueryString(params);
+ return OC.generateUrl('/s/' + token + '/download', params);
};
this.fileList.getAjaxUrl = function (action, params) {
params = params || {};
- params.t = $('#sharingToken').val();
+ params.t = token;
return OC.filePath('files_sharing', 'ajax', action + '.php') + '?' + OC.buildQueryString(params);
};
this.fileList.linkTo = function (dir) {
- var token = $('#sharingToken').val();
- var params = {
- dir: dir
- };
- return OC.generateUrl('/s/'+token+'') + '?' + OC.buildQueryString(params);
+ return OC.generateUrl('/s/' + token + '', {dir: dir});
};
this.fileList.generatePreviewUrl = function (urlSpec) {
@@ -214,6 +226,21 @@ OCA.Sharing.PublicApp = {
window.FileList = this.fileList;
},
+ _showTextPreview: function (data, previewHeight) {
+ var textDiv = $('<div/>').addClass('text-preview');
+ textDiv.text(data);
+ textDiv.appendTo('#imgframe');
+ var divHeight = textDiv.height();
+ if (data.length > 999) {
+ var ellipsis = $('<div/>').addClass('ellipsis');
+ ellipsis.html('(&#133;)');
+ ellipsis.appendTo('#imgframe');
+ }
+ if (divHeight > previewHeight) {
+ textDiv.height(previewHeight);
+ }
+ },
+
_onDirectoryChanged: function (e) {
OC.Util.History.pushState({
// arghhhh, why is this not called "dir" !?
@@ -225,7 +252,7 @@ OCA.Sharing.PublicApp = {
this.fileList.changeDirectory(params.path || params.dir, false, true);
},
- _saveToOwnCloud: function(remote, token, owner, name, isProtected) {
+ _saveToOwnCloud: function (remote, token, owner, name, isProtected) {
var location = window.location.protocol + '//' + window.location.host + OC.webroot;
var url = remote + '/index.php/apps/files#' + 'remote=' + encodeURIComponent(location) // our location is the remote for the other server