nextcloud/apps/files/js/search.js

199 lines
5.7 KiB
JavaScript
Raw Normal View History

/*
* Copyright (c) 2014
*
* This file is licensed under the Affero General Public License version 3
* or later.
*
* See the COPYING-README file.
*
*/
(function() {
/**
* Construct a new FileActions instance
* @constructs Files
*/
var Files = function() {
this.initialize();
};
/**
* @memberof OCA.Search
*/
Files.prototype = {
2015-01-05 15:11:50 +03:00
fileList: null,
/**
* Initialize the file search
*/
initialize: function() {
2014-12-31 18:02:58 +03:00
var self = this;
this.fileAppLoaded = function() {
return !!OCA.Files && !!OCA.Files.App;
};
function inFileList($row, result) {
if (! self.fileAppLoaded()) {
return false;
}
var dir = self.fileList.getCurrentDirectory().replace(/\/+$/,'');
var resultDir = OC.dirname(result.path);
return dir === resultDir && self.fileList.inList(result.name);
2014-12-31 18:02:58 +03:00
}
function updateLegacyMimetype(result) {
2014-12-31 18:02:58 +03:00
// backward compatibility:
if (!result.mime && result.mime_type) {
result.mime = result.mime_type;
}
}
function hideNoFilterResults() {
var $nofilterresults = $('.nofilterresults');
2015-01-02 14:50:21 +03:00
if ( ! $nofilterresults.hasClass('hidden') ) {
$nofilterresults.addClass('hidden');
}
}
2014-12-31 18:02:58 +03:00
this.renderFolderResult = function($row, result) {
if (inFileList($row, result)) {
return null;
}
2015-01-02 14:50:21 +03:00
hideNoFilterResults();
2014-12-31 18:02:58 +03:00
/*render folder icon, show path beneath filename,
show size and last modified date on the right */
this.updateLegacyMimetype(result);
var $pathDiv = $('<div class="path"></div>').text(result.path.substr(1, result.path.lastIndexOf("/")));
2014-12-31 18:02:58 +03:00
$row.find('td.info div.name').after($pathDiv).text(result.name);
$row.find('td.result a').attr('href', result.link);
$row.find('td.icon').css('background-image', 'url(' + OC.imagePath('core', 'filetypes/folder') + ')');
return $row;
};
this.renderFileResult = function($row, result) {
if (inFileList($row, result)) {
return null;
}
2015-01-02 14:50:21 +03:00
hideNoFilterResults();
2014-12-31 18:02:58 +03:00
/*render preview icon, show path beneath filename,
show size and last modified date on the right */
this.updateLegacyMimetype(result);
var $pathDiv = $('<div class="path"></div>').text(result.path.substr(1, result.path.lastIndexOf("/")));
2014-12-31 18:02:58 +03:00
$row.find('td.info div.name').after($pathDiv).text(result.name);
$row.find('td.result a').attr('href', result.link);
if (self.fileAppLoaded()) {
2015-01-05 15:11:50 +03:00
self.fileList.lazyLoadPreview({
2014-12-31 18:02:58 +03:00
path: result.path,
mime: result.mime,
callback: function (url) {
$row.find('td.icon').css('background-image', 'url(' + url + ')');
}
});
} else {
// FIXME how to get mime icon if not in files app
var mimeicon = result.mime.replace('/', '-');
$row.find('td.icon').css('background-image', 'url(' + OC.imagePath('core', 'filetypes/' + mimeicon) + ')');
var dir = OC.dirname(result.path);
if (dir === '') {
dir = '/';
}
$row.find('td.info a').attr('href',
OC.generateUrl('/apps/files/?dir={dir}&scrollto={scrollto}', {dir: dir, scrollto: result.name})
);
}
return $row;
};
this.renderAudioResult = function($row, result) {
/*render preview icon, show path beneath filename,
show size and last modified date on the right
show Artist and Album */
$row = this.renderFileResult($row, result);
if ($row) {
$row.find('td.icon').css('background-image', 'url(' + OC.imagePath('core', 'filetypes/audio') + ')');
}
return $row;
};
this.renderImageResult = function($row, result) {
/*render preview icon, show path beneath filename,
show size and last modified date on the right
show width and height */
$row = this.renderFileResult($row, result);
if ($row && !self.fileAppLoaded()) {
$row.find('td.icon').css('background-image', 'url(' + OC.imagePath('core', 'filetypes/image') + ')');
}
return $row;
};
this.handleFolderClick = function($row, result, event) {
// open folder
if (self.fileAppLoaded() && self.fileList.id === 'files') {
2015-01-05 15:11:50 +03:00
self.fileList.changeDirectory(result.path);
2014-12-31 18:02:58 +03:00
return false;
} else {
return true;
}
};
this.handleFileClick = function($row, result, event) {
if (self.fileAppLoaded() && self.fileList.id === 'files') {
2015-01-05 15:11:50 +03:00
self.fileList.changeDirectory(OC.dirname(result.path));
self.fileList.scrollTo(result.name);
2014-12-31 18:02:58 +03:00
return false;
} else {
return true;
}
};
2014-12-31 18:36:00 +03:00
this.updateLegacyMimetype = function (result) {
// backward compatibility:
if (!result.mime && result.mime_type) {
result.mime = result.mime_type;
}
};
2015-01-05 15:11:50 +03:00
this.setFileList = function (fileList) {
this.fileList = fileList;
};
2014-12-31 18:36:00 +03:00
OC.Plugins.register('OCA.Search', this);
},
attach: function(search) {
2014-12-31 16:28:01 +03:00
var self = this;
search.setFilter('files', function (query) {
2014-12-31 16:28:01 +03:00
if (self.fileAppLoaded()) {
2015-01-05 15:11:50 +03:00
self.fileList.setFilter(query);
if (query.length > 2) {
//search is not started until 500msec have passed
window.setTimeout(function() {
$('.nofilterresults').addClass('hidden');
}, 500);
}
}
});
2014-12-31 18:36:00 +03:00
search.setRenderer('folder', this.renderFolderResult.bind(this));
search.setRenderer('file', this.renderFileResult.bind(this));
search.setRenderer('audio', this.renderAudioResult.bind(this));
search.setRenderer('image', this.renderImageResult.bind(this));
2014-12-31 18:36:00 +03:00
search.setHandler('folder', this.handleFolderClick.bind(this));
search.setHandler(['file', 'audio', 'image'], this.handleFileClick.bind(this));
if (self.fileAppLoaded()) {
// hide results when switching directory outside of search results
$('#app-content').delegate('>div', 'changeDirectory', function() {
search.clear();
});
}
}
};
OCA.Search.Files = Files;
2015-01-05 15:11:50 +03:00
OCA.Search.files = new Files();
})();