|
|
|
@ -129,6 +129,7 @@ define([
|
|
|
|
|
//var $ownerIcon = $('<span>', {"class": "fa fa-id-card"});
|
|
|
|
|
var $tagsIcon = $('<span>', {"class": "fa " + faTags});
|
|
|
|
|
var $passwordIcon = $('<span>', {"class": "fa fa-lock"});
|
|
|
|
|
var $restrictedIcon = $('<span>', {"class": "fa fa-ban"});
|
|
|
|
|
var $expirableIcon = $('<span>', {"class": "fa fa-clock-o"});
|
|
|
|
|
var $separator = $('<div>', {"class": "dropdown-divider"});
|
|
|
|
|
|
|
|
|
@ -1211,6 +1212,9 @@ define([
|
|
|
|
|
if (!$element.is('.cp-app-drive-element-owned')) {
|
|
|
|
|
hide.push('deleteowned');
|
|
|
|
|
}
|
|
|
|
|
if ($element.is('.cp-app-drive-element-restricted')) {
|
|
|
|
|
hide.push('rename', 'download', 'share', 'access', 'color');
|
|
|
|
|
}
|
|
|
|
|
if ($element.is('.cp-app-drive-element-notrash')) {
|
|
|
|
|
// We can't delete elements in virtual categories
|
|
|
|
|
hide.push('delete');
|
|
|
|
@ -1949,7 +1953,8 @@ define([
|
|
|
|
|
var $ro;
|
|
|
|
|
if (manager.isSharedFolder(element)) {
|
|
|
|
|
var data = manager.getSharedFolderData(element);
|
|
|
|
|
key = data && data.title ? data.title : key;
|
|
|
|
|
var fId = element;
|
|
|
|
|
key = data.title || data.lastTitle;
|
|
|
|
|
element = manager.folders[element].proxy[manager.user.userObject.ROOT];
|
|
|
|
|
$span.addClass('cp-app-drive-element-sharedf');
|
|
|
|
|
_addOwnership($span, $state, data);
|
|
|
|
@ -1964,6 +1969,11 @@ define([
|
|
|
|
|
$ro.attr('title', Messages.readonly);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (files.restrictedFolders[fId]) {
|
|
|
|
|
var $restricted = $restrictedIcon.clone().appendTo($state);
|
|
|
|
|
$restricted.attr('title', Messages.fm_restricted);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var $shared = $sharedIcon.clone().appendTo($state);
|
|
|
|
|
$shared.attr('title', Messages.fm_canBeShared);
|
|
|
|
|
} else if ($content.data('readOnlyFolder') || APP.readOnly) {
|
|
|
|
@ -1972,14 +1982,14 @@ define([
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var sf = manager.hasSubfolder(element);
|
|
|
|
|
var files = manager.hasFile(element);
|
|
|
|
|
var hasFiles = manager.hasFile(element);
|
|
|
|
|
var $name = $('<span>', {'class': 'cp-app-drive-element-name'}).text(key);
|
|
|
|
|
var $subfolders = $('<span>', {
|
|
|
|
|
'class': 'cp-app-drive-element-folders cp-app-drive-element-list'
|
|
|
|
|
}).text(sf);
|
|
|
|
|
var $files = $('<span>', {
|
|
|
|
|
'class': 'cp-app-drive-element-files cp-app-drive-element-list'
|
|
|
|
|
}).text(files);
|
|
|
|
|
}).text(hasFiles);
|
|
|
|
|
var $filler = $('<span>', {
|
|
|
|
|
'class': 'cp-app-drive-element-filler cp-app-drive-element-list'
|
|
|
|
|
});
|
|
|
|
@ -2034,6 +2044,7 @@ define([
|
|
|
|
|
return $shareBlock;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
Messages.fm_restricted = "Forbidden access"; // XXX
|
|
|
|
|
// Create the "li" element corresponding to the file/folder located in "path"
|
|
|
|
|
var createElement = function (path, elPath, root, isFolder) {
|
|
|
|
|
// Forbid drag&drop inside the trash
|
|
|
|
@ -2051,32 +2062,38 @@ define([
|
|
|
|
|
element = root[key];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var restricted = files.restrictedFolders[element];
|
|
|
|
|
var isSharedFolder = manager.isSharedFolder(element);
|
|
|
|
|
|
|
|
|
|
var $icon = !isFolder ? getFileIcon(element) : undefined;
|
|
|
|
|
var ro = manager.isReadOnlyFile(element);
|
|
|
|
|
// ro undefined means it's an old hash which doesn't support read-only
|
|
|
|
|
var roClass = typeof(ro) === 'undefined' ?' cp-app-drive-element-noreadonly' :
|
|
|
|
|
ro ? ' cp-app-drive-element-readonly' : '';
|
|
|
|
|
var liClass = 'cp-app-drive-element-file cp-app-drive-element' + roClass;
|
|
|
|
|
var roClass = typeof(ro) === 'undefined' ? '.cp-app-drive-element-noreadonly' :
|
|
|
|
|
ro ? '.cp-app-drive-element-readonly' : '';
|
|
|
|
|
var liClass = '.cp-app-drive-element-file';
|
|
|
|
|
var restrictedClass = restricted ? '.cp-app-drive-element-restricted' : '';
|
|
|
|
|
if (isSharedFolder) {
|
|
|
|
|
liClass = 'cp-app-drive-element-folder cp-app-drive-element';
|
|
|
|
|
liClass = '.cp-app-drive-element-folder';
|
|
|
|
|
$icon = $sharedFolderIcon.clone();
|
|
|
|
|
$icon.css("color", getFolderColor(path.concat(elPath)));
|
|
|
|
|
} else if (isFolder) {
|
|
|
|
|
liClass = 'cp-app-drive-element-folder cp-app-drive-element';
|
|
|
|
|
liClass = '.cp-app-drive-element-folder';
|
|
|
|
|
$icon = manager.isFolderEmpty(root[key]) ? $folderEmptyIcon.clone() : $folderIcon.clone();
|
|
|
|
|
$icon.css("color", getFolderColor(path.concat(elPath)));
|
|
|
|
|
}
|
|
|
|
|
var $element = $('<li>', {
|
|
|
|
|
draggable: true,
|
|
|
|
|
'class': 'cp-app-drive-element-row'
|
|
|
|
|
});
|
|
|
|
|
var classes = restrictedClass + roClass + liClass;
|
|
|
|
|
var $element = $(h('li.cp-app-drive-element.cp-app-drive-element-row' + classes, {
|
|
|
|
|
draggable: true
|
|
|
|
|
}));
|
|
|
|
|
$element.data('path', newPath);
|
|
|
|
|
if (isElementSelected($element)) {
|
|
|
|
|
selectElement($element);
|
|
|
|
|
}
|
|
|
|
|
$element.prepend($icon).dblclick(function () {
|
|
|
|
|
if (restricted) {
|
|
|
|
|
UI.warn(Messages.fm_restricted);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
if (isFolder) {
|
|
|
|
|
APP.displayDirectory(newPath);
|
|
|
|
|
return;
|
|
|
|
@ -2100,8 +2117,7 @@ define([
|
|
|
|
|
}
|
|
|
|
|
e.stopPropagation();
|
|
|
|
|
});
|
|
|
|
|
$element.addClass(liClass);
|
|
|
|
|
var droppable = !isTrash && !APP.$content.data('readOnlyFolder');
|
|
|
|
|
var droppable = !isTrash && !APP.$content.data('readOnlyFolder') && !restricted;
|
|
|
|
|
addDragAndDropHandlers($element, newPath, isFolder, droppable);
|
|
|
|
|
$element.click(function(e) {
|
|
|
|
|
e.stopPropagation();
|
|
|
|
@ -3600,6 +3616,13 @@ define([
|
|
|
|
|
var $list = $('<ul>').appendTo($dirContent);
|
|
|
|
|
|
|
|
|
|
var sfId = manager.isInSharedFolder(currentPath);
|
|
|
|
|
|
|
|
|
|
// Restricted folder? display ROOT instead
|
|
|
|
|
if (sfId && files.restrictedFolders[sfId]) {
|
|
|
|
|
_displayDirectory([ROOT], true);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var readOnlyFolder = false;
|
|
|
|
|
if (APP.readOnly) {
|
|
|
|
|
// Read-only drive (team?)
|
|
|
|
@ -3753,8 +3776,15 @@ define([
|
|
|
|
|
}
|
|
|
|
|
var $elementRow = $('<span>', {'class': 'cp-app-drive-element-row'}).append($collapse).append($icon).append($name).click(function (e) {
|
|
|
|
|
e.stopPropagation();
|
|
|
|
|
if (files.restrictedFolders[isSharedFolder]) {
|
|
|
|
|
UI.warn(Messages.fm_restricted);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
APP.displayDirectory(path);
|
|
|
|
|
});
|
|
|
|
|
if (files.restrictedFolders[isSharedFolder]) {
|
|
|
|
|
$elementRow.addClass('cp-app-drive-element-restricted');
|
|
|
|
|
}
|
|
|
|
|
if (isSharedFolder) {
|
|
|
|
|
var sfData = manager.getSharedFolderData(isSharedFolder);
|
|
|
|
|
_addOwnership($elementRow, $(), sfData);
|
|
|
|
@ -3837,7 +3867,7 @@ define([
|
|
|
|
|
if (!manager.isFolder(root[key])) { return; }
|
|
|
|
|
var newPath = path.slice();
|
|
|
|
|
newPath.push(key);
|
|
|
|
|
var isSharedFolder = manager.isSharedFolder(root[key]);
|
|
|
|
|
var isSharedFolder = manager.isSharedFolder(root[key]) && root[key];
|
|
|
|
|
var sfId = manager.isInSharedFolder(newPath) || (isSharedFolder && root[key]);
|
|
|
|
|
var $icon, isCurrentFolder, subfolder;
|
|
|
|
|
if (isSharedFolder) {
|
|
|
|
@ -4130,6 +4160,10 @@ define([
|
|
|
|
|
else if ($this.hasClass('cp-app-drive-context-open')) {
|
|
|
|
|
paths.forEach(function (p) {
|
|
|
|
|
var el = manager.find(p.path);
|
|
|
|
|
if (files.restrictedFolders[el]) {
|
|
|
|
|
UI.warn(Messages.fm_restricted);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
openFile(el, false, true);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
@ -4715,7 +4749,6 @@ define([
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
*/
|
|
|
|
|
var deprecated = files.sharedFoldersTemp;
|
|
|
|
|
var nt = nThen;
|
|
|
|
|
var passwordModal = function (fId, data, cb) {
|
|
|
|
|
var content = [];
|
|
|
|
@ -4771,6 +4804,7 @@ define([
|
|
|
|
|
onClose: cb
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
var deprecated = files.sharedFoldersTemp;
|
|
|
|
|
if (typeof (deprecated) === "object" && APP.editable && Object.keys(deprecated).length) {
|
|
|
|
|
Object.keys(deprecated).forEach(function (fId) {
|
|
|
|
|
var data = deprecated[fId];
|
|
|
|
@ -4787,7 +4821,6 @@ define([
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return {
|
|
|
|
|
refresh: refresh,
|
|
|
|
|
close: function () {
|
|
|
|
|