summaryrefslogtreecommitdiffstats
path: root/search
diff options
context:
space:
mode:
authorJörn Friedrich Dreyer <jfd@butonic.de>2014-12-06 00:53:06 +0100
committerJörn Friedrich Dreyer <jfd@butonic.de>2015-01-02 10:28:41 +0100
commitd3662722f66eb5b97593922a11e5357eff0fb042 (patch)
treedd45389e024f914ff5e454e0523b82f3349fdd48 /search
parent0ba3093196fee7079583847b40ef3a8e00df47a7 (diff)
downloadnextcloud-server-d3662722f66eb5b97593922a11e5357eff0fb042.tar.gz
nextcloud-server-d3662722f66eb5b97593922a11e5357eff0fb042.zip
new OC.Search, add search result formatters and handlers, use full content width for results
Diffstat (limited to 'search')
-rw-r--r--search/css/results.css34
-rw-r--r--search/js/result.js211
-rw-r--r--search/templates/part.results.php11
3 files changed, 128 insertions, 128 deletions
diff --git a/search/css/results.css b/search/css/results.css
index 8bcf2348df2..78b60e65e45 100644
--- a/search/css/results.css
+++ b/search/css/results.css
@@ -11,21 +11,10 @@
top:0;
padding-top: 45px;
height: 100%;
+ box-sizing: border-box;
z-index:75;
}
-#searchresults li.resultHeader {
- background-color:#eee;
- border-bottom:solid 1px #CCC;
- font-size:1.2em;
- font-weight:700;
- padding:.2em;
-}
-
-#searchresults li.result {
- margin-left:2em;
-}
-
#searchresults table {
border-spacing:0;
table-layout:fixed;
@@ -64,26 +53,17 @@
opacity: 1;
}
-#searchresults td.result * {
+#searchresults tr.result * {
cursor:pointer;
}
-#searchresults td.container {
- width:20px;
-}
-
-#searchresults td.container img {
- vertical-align: middle;
- display:none;
-}
-#searchresults tr:hover td.container img {
- display:inline;
-}
-
-#searchresults td.type {
+#searchresults td.icon {
font-weight:700;
text-align:right;
- width:3.5em;
+ width:32px;
+ height: 40px;
+ background-position: 30px 4px;
+ background-repeat: no-repeat;
}
#searchresults tr.current {
diff --git a/search/js/result.js b/search/js/result.js
index 147377aff0c..3d3cbd56aea 100644
--- a/search/js/result.js
+++ b/search/js/result.js
@@ -9,24 +9,13 @@
*/
//translations for result type ids, can be extended by apps
-OC.search.resultTypes={
+OC.Search.resultTypes={
file: t('core','File'),
folder: t('core','Folder'),
image: t('core','Image'),
audio: t('core','Audio')
};
-OC.search.catagorizeResults=function(results){
- var types={};
- for(var i=0;i<results.length;i++){
- var type=results[i].type;
- if(!types[type]){
- types[type]=[];
- }
- types[type].push(results[i]);
- }
- return types;
-};
-OC.search.hide=function(){
+OC.Search.hide=function(){
$('#searchresults').hide();
if($('#searchbox').val().length>2){
$('#searchbox').val('');
@@ -40,117 +29,149 @@ OC.search.hide=function(){
}
}
};
-OC.search.showResults=function(results){
+OC.Search.showResults=function(results){
if(results.length === 0){
return;
}
- if(!OC.search.showResults.loaded){
+ if(!OC.Search.showResults.loaded){
var parent=$('<div class="searchresults-wrapper"/>');
$('#app-content').append(parent);
parent.load(OC.filePath('search','templates','part.results.php'),function(){
- OC.search.showResults.loaded=true;
+ OC.Search.showResults.loaded=true;
$('#searchresults').click(function(event){
- OC.search.hide();
+ OC.Search.hide();
event.stopPropagation();
});
$(document).click(function(event){
- OC.search.hide();
+ OC.Search.hide();
if (FileList && typeof FileList.unfilter === 'function') { //TODO add hook system
FileList.unfilter();
}
});
- OC.search.lastResults=results;
- OC.search.showResults(results);
+ OC.Search.lastResults=results;
+ OC.Search.showResults(results);
});
- }else{
- var types=OC.search.catagorizeResults(results);
- $('#searchresults').show();
+ } else {
$('#searchresults tr.result').remove();
- var index=0;
- for(var typeid in types){
- var type=types[typeid];
- if(type.length>0){
- for(var i=0;i<type.length;i++){
- var row=$('#searchresults tr.template').clone();
- row.removeClass('template');
- row.addClass('result');
-
- row.data('type', typeid);
- row.data('name', type[i].name);
- row.data('path', type[i].path);
- row.data('text', type[i].text);
- row.data('index',index);
-
- if (i === 0){
- var typeName = OC.search.resultTypes[typeid];
- row.children('td.type').text(t('lib', typeName));
- }
-
- if (type[i].path) {
- OCA.Files.App.fileList.lazyLoadPreview({
- path: type[i].path,
- mime: type[i].mime_type,
- callback: function (url) {
- row.find('td.type').css('background-image', 'url(' + url + ')');
- }
- });
- }
+ $('#searchresults').show();
+ jQuery.each(results, function(i, result) {
+ var $row = $('#searchresults tr.template').clone();
+ $row.removeClass('template');
+ $row.addClass('result');
- row.find('td.result div.name').text(type[i].name);
- row.find('td.result div.path').text(type[i].path);
- if (typeof type[i].highlights === 'object') {
- var highlights = type[i].highlights.join(' … ');
- row.find('td.result div.text').html(highlights);
- } else {
- row.find('td.result div.text').text(type[i].text);
- }
+ $row.data('result', result);
- if (type[i].path) {
- var parent = OC.dirname(type[i].path);
- if (parent === '') {
- parent = '/';
- }
- var containerName = OC.basename(parent);
- if (containerName === '') {
- containerName = '/';
- }
- var containerLink = OC.linkTo('files', 'index.php')
- +'/?dir='+encodeURIComponent(parent)
- +'&scrollto='+encodeURIComponent(type[i].name);
- row.find('td.result a')
- .attr('href', containerLink)
- .attr('title', t('core', 'Show in {folder}', {folder: containerName}));
- } else {
- row.find('td.result a').attr('href', type[i].link);
- }
+ // generic results only have four attributes
+ $row.find('td.info div.name').text(result.name);
+ $row.find('td.info a').attr('href', result.link);
- index++;
- /**
- * Give plugins the ability to customize the search results. For example:
- * OC.search.customResults.file = function (row, item){
- * if(item.name.search('.json') >= 0) ...
- * };
- */
- if(OC.search.customResults[typeid]){
- OC.search.customResults[typeid](row, type[i]);
- }
- $('#searchresults tbody').append(row);
+ $row.find('td.icon').css('background-image', 'url(' + OC.imagePath('core', 'places/link') + ')');
+ /**
+ * Give plugins the ability to customize the search results. For example:
+ * OC.search.customResults.file = function (row, item){
+ * if(item.name.search('.json') >= 0) ...
+ * };
+ */
+ if(OC.Search.hasFormatter(result.type)){
+ OC.Search.getFormatter(result.type)($row, result);
+ } else
+ {
+ // for backward compatibility add text div
+ $row.find('td.info div.name').addClass('result')
+ $row.find('td.result div.name').after('<div class="text"></div>');
+ $row.find('td.result div.text').text(result.name);
+ if(OC.search.customResults[result.type]){
+ OC.search.customResults[result.type]($row, result);
}
}
- }
- $('#searchresults').on('click', 'result', function () {
- if ($(this).data('type') === 'Files') {
- //FIXME use ajax to navigate to folder & highlight file
+ $('#searchresults tbody').append($row);
+ });
+
+ $('#searchresults').on('click', 'tr.result', function (event) {
+ var $row = $(this);
+ var result = $row.data('result');
+ if(OC.Search.hasHandler(result.type)){
+ var result = OC.Search.getHandler(result.type)($row, result, event);
+ OC.Search.hide();
+ event.stopPropagation();
+ return result;
}
});
}
};
-OC.search.showResults.loaded=false;
+OC.Search.showResults.loaded=false;
-OC.search.renderCurrent=function(){
+OC.Search.renderCurrent=function(){
if($('#searchresults tr.result')[OC.search.currentResult]){
var result=$('#searchresults tr.result')[OC.search.currentResult];
$('#searchresults tr.result').removeClass('current');
$(result).addClass('current');
}
};
+
+OC.Search.setFormatter('file', function ($row, result) {
+ // backward compatibility:
+ if (typeof result.mime !== 'undefined') {
+ result.mime_type = result.mime;
+ } else if (typeof result.mime_type !== 'undefined') {
+ result.mime = result.mime_type;
+ }
+
+ $pathDiv = $('<div class="path"></div>').text(result.path)
+ $row.find('td.info div.name').after($pathDiv).text(result.name);
+
+ $row.find('td.result a').attr('href', result.link);
+
+ if (OCA.Files) {
+ OCA.Files.App.fileList.lazyLoadPreview({
+ 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})
+ );
+ }
+});
+OC.Search.setHandler('file', function ($row, result, event) {
+ if (OCA.Files) {
+ OCA.Files.App.fileList.changeDirectory(OC.dirname(result.path));
+ OCA.Files.App.fileList.scrollTo(result.name);
+ return false;
+ } else {
+ return true;
+ }
+});
+
+OC.Search.setFormatter('folder', function ($row, result) {
+ // backward compatibility:
+ if (typeof result.mime !== 'undefined') {
+ result.mime_type = result.mime;
+ } else if (typeof result.mime_type !== 'undefined') {
+ result.mime = result.mime_type;
+ }
+
+ var $pathDiv = $('<div class="path"></div>').text(result.path)
+ $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') + ')');
+});
+OC.Search.setHandler('folder', function ($row, result, event) {
+ if (OCA.Files) {
+ OCA.Files.App.fileList.changeDirectory(result.path);
+ return false;
+ } else {
+ return true;
+ }
+});
diff --git a/search/templates/part.results.php b/search/templates/part.results.php
index 4a5cdd1b3eb..451df7b143f 100644
--- a/search/templates/part.results.php
+++ b/search/templates/part.results.php
@@ -1,13 +1,12 @@
<div id="searchresults">
+ <!-- p>{message}</p -->
<table>
<tbody>
<tr class="template">
- <td class="type"></td>
- <td class="result">
- <a>
- <div class="name"></div><div class="storage"></div>
- <div class="path"></div>
- <div class="text"></div>
+ <td class="icon"></td>
+ <td class="info">
+ <a class="link">
+ <div class="name"></div>
</a>
</td>
</tr>