2016-10-01 18:34:18 +00:00
|
|
|
"use strict";
|
|
|
|
|
|
|
|
// Copyright (c) 2015 - 2016 Dane Everitt <dane@daneeveritt.com>
|
|
|
|
//
|
|
|
|
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
// of this software and associated documentation files (the "Software"), to deal
|
|
|
|
// in the Software without restriction, including without limitation the rights
|
|
|
|
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
// copies of the Software, and to permit persons to whom the Software is
|
|
|
|
// furnished to do so, subject to the following conditions:
|
|
|
|
//
|
|
|
|
// The above copyright notice and this permission notice shall be included in all
|
|
|
|
// copies or substantial portions of the Software.
|
|
|
|
//
|
|
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
|
|
// SOFTWARE.
|
2016-10-03 19:15:06 +00:00
|
|
|
class ContextMenuClass {
|
|
|
|
constructor() {
|
|
|
|
this.activeLine = null;
|
2016-10-01 18:34:18 +00:00
|
|
|
}
|
|
|
|
|
2016-10-03 19:15:06 +00:00
|
|
|
run() {
|
|
|
|
this.directoryClick();
|
|
|
|
this.rightClick();
|
2016-10-01 18:34:18 +00:00
|
|
|
}
|
|
|
|
|
2016-10-06 23:39:45 +00:00
|
|
|
makeMenu(parent) {
|
2016-10-03 19:15:06 +00:00
|
|
|
$(document).find('#fileOptionMenu').remove();
|
|
|
|
if (!_.isNull(this.activeLine)) this.activeLine.removeClass('active');
|
2016-10-06 23:39:45 +00:00
|
|
|
|
|
|
|
let newFilePath = $('#headerTableRow').attr('data-currentDir');
|
|
|
|
if (parent.data('type') === 'folder') {
|
|
|
|
const nameBlock = parent.find('td[data-identifier="name"]');
|
|
|
|
const currentName = decodeURIComponent(nameBlock.attr('data-name'));
|
|
|
|
const currentPath = decodeURIComponent(nameBlock.data('path'));
|
|
|
|
newFilePath = `${currentPath}${currentName}`;
|
|
|
|
}
|
2016-10-03 19:15:06 +00:00
|
|
|
return '<ul id="fileOptionMenu" class="dropdown-menu" role="menu" style="display:none" > \
|
|
|
|
<li data-action="move"><a tabindex="-1" href="#"><i class="fa fa-arrow-right"></i> Move</a></li> \
|
2016-10-06 23:15:40 +00:00
|
|
|
<li data-action="copy"><a tabindex="-1" href="#"><i class="fa fa-clone"></i> Copy</a></li> \
|
2016-10-03 19:15:06 +00:00
|
|
|
<li data-action="rename"><a tabindex="-1" href="#"><i class="fa fa-pencil-square-o"></i> Rename</a></li> \
|
|
|
|
<li data-action="compress" class="hidden"><a tabindex="-1" href="#"><i class="fa fa-file-archive-o"></i> Compress</a></li> \
|
|
|
|
<li data-action="decompress" class="hidden"><a tabindex="-1" href="#"><i class="fa fa-expand"></i> Decompress</a></li> \
|
|
|
|
<li class="divider"></li> \
|
2016-10-06 23:39:45 +00:00
|
|
|
<li data-action="file"><a href="/server/{{ $server->uuidShort }}/files/add/?dir=' + newFilePath + '" class="text-muted"><i class="fa fa-plus"></i> New File</a></li> \
|
|
|
|
<li data-action="folder"><a tabindex="-1" href="#"><i class="fa fa-folder"></i> New Folder</a></li> \
|
|
|
|
<li class="divider"></li> \
|
2016-10-05 01:38:22 +00:00
|
|
|
<li data-action="download" class="hidden"><a tabindex="-1" href="#"><i class="fa fa-download"></i> Download</a></li> \
|
2016-10-03 19:15:06 +00:00
|
|
|
<li data-action="delete" class="bg-danger"><a tabindex="-1" href="#"><i class="fa fa-trash-o"></i> Delete</a></li> \
|
|
|
|
</ul>';
|
2016-10-01 18:34:18 +00:00
|
|
|
}
|
|
|
|
|
2016-10-03 19:15:06 +00:00
|
|
|
rightClick() {
|
|
|
|
$('#file_listing > tbody td').on('contextmenu', event => {
|
2016-10-02 03:09:55 +00:00
|
|
|
|
2016-10-06 21:27:50 +00:00
|
|
|
const parent = $(event.target).closest('tr');
|
2016-10-06 23:39:45 +00:00
|
|
|
const menu = $(this.makeMenu(parent));
|
2016-10-03 19:15:06 +00:00
|
|
|
|
|
|
|
if (parent.data('type') === 'disabled') return;
|
|
|
|
event.preventDefault();
|
|
|
|
|
|
|
|
$(menu).appendTo('body');
|
|
|
|
$(menu).data('invokedOn', $(event.target)).show().css({
|
|
|
|
position: 'absolute',
|
|
|
|
left: event.pageX,
|
|
|
|
top: event.pageY,
|
|
|
|
});
|
|
|
|
|
|
|
|
this.activeLine = parent;
|
|
|
|
this.activeLine.addClass('active');
|
2016-10-02 03:09:55 +00:00
|
|
|
|
2016-10-03 19:15:06 +00:00
|
|
|
if (parent.data('type') === 'file') {
|
|
|
|
$(menu).find('li[data-action="download"]').removeClass('hidden');
|
2016-10-01 18:34:18 +00:00
|
|
|
}
|
|
|
|
|
2016-10-03 19:15:06 +00:00
|
|
|
if (parent.data('type') === 'folder') {
|
|
|
|
$(menu).find('li[data-action="compress"]').removeClass('hidden');
|
|
|
|
}
|
|
|
|
|
|
|
|
if (_.without(['application/zip', 'application/gzip', 'application/x-gzip'], parent.data('mime')).length < 3) {
|
|
|
|
$(menu).find('li[data-action="decompress"]').removeClass('hidden');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Handle Events
|
|
|
|
const Actions = new ActionsClass(parent, menu);
|
|
|
|
$(menu).find('li[data-action="move"]').unbind().on('click', e => {
|
2016-10-03 20:36:12 +00:00
|
|
|
e.preventDefault();
|
2016-10-03 19:15:06 +00:00
|
|
|
Actions.move();
|
|
|
|
});
|
|
|
|
|
2016-10-06 23:15:40 +00:00
|
|
|
$(menu).find('li[data-action="copy"]').unbind().on('click', e => {
|
|
|
|
e.preventDefault();
|
|
|
|
Actions.copy();
|
|
|
|
});
|
|
|
|
|
2016-10-03 19:15:06 +00:00
|
|
|
$(menu).find('li[data-action="rename"]').unbind().on('click', e => {
|
2016-10-03 20:36:12 +00:00
|
|
|
e.preventDefault();
|
2016-10-03 19:15:06 +00:00
|
|
|
Actions.rename();
|
2016-10-01 18:34:18 +00:00
|
|
|
});
|
2016-10-03 19:15:06 +00:00
|
|
|
|
2016-10-05 01:38:22 +00:00
|
|
|
$(menu).find('li[data-action="compress"]').unbind().on('click', e => {
|
|
|
|
e.preventDefault();
|
|
|
|
Actions.compress();
|
|
|
|
});
|
|
|
|
|
|
|
|
$(menu).find('li[data-action="decompress"]').unbind().on('click', e => {
|
|
|
|
e.preventDefault();
|
|
|
|
Actions.decompress();
|
|
|
|
});
|
|
|
|
|
2016-10-06 23:39:45 +00:00
|
|
|
$(menu).find('li[data-action="folder"]').unbind().on('click', e => {
|
|
|
|
e.preventDefault();
|
|
|
|
Actions.folder();
|
|
|
|
});
|
|
|
|
|
2016-10-03 19:15:06 +00:00
|
|
|
$(menu).find('li[data-action="download"]').unbind().on('click', e => {
|
|
|
|
e.preventDefault();
|
|
|
|
Actions.download();
|
|
|
|
});
|
|
|
|
|
2016-10-03 20:36:12 +00:00
|
|
|
$(menu).find('li[data-action="delete"]').unbind().on('click', e => {
|
|
|
|
e.preventDefault();
|
|
|
|
Actions.delete();
|
|
|
|
});
|
|
|
|
|
2016-10-03 19:15:06 +00:00
|
|
|
$(window).on('click', () => {
|
|
|
|
$(menu).remove();
|
|
|
|
if(!_.isNull(this.activeLine)) this.activeLine.removeClass('active');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
directoryClick() {
|
|
|
|
$('a[data-action="directory-view"]').on('click', function (event) {
|
|
|
|
event.preventDefault();
|
|
|
|
|
|
|
|
const path = $(this).parent().data('path') || '';
|
|
|
|
const name = $(this).parent().data('name') || '';
|
|
|
|
|
|
|
|
window.location.hash = encodeURIComponent(path + name);
|
|
|
|
Files.list();
|
2016-10-01 18:34:18 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
2016-10-03 19:15:06 +00:00
|
|
|
|
|
|
|
window.ContextMenu = new ContextMenuClass;
|