Skip to content

Commit d812e1a

Browse files
committed
Very rough base implementation of file renaming
1 parent 3dbe899 commit d812e1a

File tree

5 files changed

+287
-138
lines changed

5 files changed

+287
-138
lines changed

resources/views/server/files/index.blade.php

Lines changed: 20 additions & 121 deletions
Original file line numberDiff line numberDiff line change
@@ -23,6 +23,12 @@
2323
Managing Files for: {{ $server->name }}
2424
@endsection
2525

26+
@section('scripts')
27+
@parent
28+
{!! Theme::js('js/vendor/async/async.min.js') !!}
29+
{!! Theme::js('js/vendor/lodash/lodash.js') !!}
30+
@endsection
31+
2632
@section('content')
2733
<div class="col-md-12">
2834
<div class="row">
@@ -50,128 +56,21 @@
5056
</div>
5157
</div>
5258
</div>
59+
<ul id="fileOptionMenu" class="dropdown-menu" role="menu" style="display:none" >
60+
<li data-action="move"><a tabindex="-1" href="#"><i class="fa fa-arrow-right"></i> Move</a></li>
61+
<li data-action="rename"><a tabindex="-1" href="#"><i class="fa fa-pencil-square-o"></i> Rename</a></li>
62+
<li><a tabindex="-1" href="#"><i class="fa fa-file-archive-o"></i> Compress</a></li>
63+
<li class="divider"></li>
64+
<li><a tabindex="-1" href="#"><i class="fa fa-download"></i> Download</a></li>
65+
<li><a tabindex="-1" href="#"><i class="fa fa-trash-o"></i> Delete</a></li>
66+
</ul>
5367
</div>
68+
<script src="{{ route('server.js', [$server->uuidShort, 'filemanager', 'index.js']) }}"></script>
69+
<script src="{{ route('server.js', [$server->uuidShort, 'filemanager', 'actions.js']) }}"></script>
70+
<script src="{{ route('server.js', [$server->uuidShort, 'filemanager', 'contextmenu.js']) }}"></script>
5471
<script>
55-
$(document).ready(function () {
56-
$('.server-files').addClass('active');
57-
});
58-
$(window).load(function(){
59-
var doneLoad = false;
60-
61-
// Show Loading Animation
62-
function handleLoader (show) {
63-
64-
// Hide animation if no files displayed.
65-
if ($('#load_files').height() < 5) { return; }
66-
67-
// Show Animation
68-
if (show === true){
69-
var height = $('#load_files').height();
70-
var width = $('.ajax_loading_box').width();
71-
var center_height = (height / 2) - 30;
72-
var center_width = (width / 2) - 30;
73-
$('#position_me').css({
74-
'top': center_height,
75-
'left': center_width,
76-
'font-size': '60px'
77-
});
78-
$(".ajax_loading_box").css('height', (height + 5)).fadeIn();
79-
} else {
80-
$('.ajax_loading_box').fadeOut(100);
81-
}
82-
83-
}
84-
85-
function reloadActions () {
86-
reloadActionClick();
87-
reloadActionDelete();
88-
}
89-
90-
// Handle folder clicking to load new contents
91-
function reloadActionClick () {
92-
$('a.load_new').click(function (e) {
93-
e.preventDefault();
94-
window.history.pushState(null, null, $(this).attr('href'));
95-
loadDirectoryContents($.urlParam('dir', $(this).attr('href')));
96-
});
97-
}
98-
99-
// Handle Deleting Files
100-
function reloadActionDelete () {
101-
$('[data-action="delete_file"]').click(function (e) {
102-
e.preventDefault();
103-
var clicked = $(this);
104-
var deleteItemPath = $(this).attr('href');
105-
106-
swal({
107-
type: 'warning',
108-
title: '',
109-
text: 'Are you sure you want to delete <code>' + clicked.data('name') + '</code>?',
110-
html: true,
111-
showCancelButton: true,
112-
showConfirmButton: true,
113-
closeOnConfirm: false,
114-
showLoaderOnConfirm: true
115-
}, function () {
116-
$.ajax({
117-
type: 'DELETE',
118-
url: '{{ $node->scheme }}://{{ $node->fqdn }}:{{ $node->daemonListen }}/server/file/' + deleteItemPath,
119-
headers: {
120-
'X-Access-Token': '{{ $server->daemonSecret }}',
121-
'X-Access-Server': '{{ $server->uuid }}'
122-
}
123-
}).done(function (data) {
124-
clicked.parent().parent().parent().parent().fadeOut();
125-
swal({
126-
type: 'success',
127-
title: 'File Deleted'
128-
});
129-
}).fail(function (jqXHR) {
130-
console.error(jqXHR);
131-
swal({
132-
type: 'error',
133-
title: 'Whoops!',
134-
html: true,
135-
text: 'An error occured while attempting to delete this file. Please try again.',
136-
});
137-
});
138-
});
139-
140-
});
141-
}
142-
143-
// Handle Loading Contents
144-
function loadDirectoryContents (dir) {
145-
146-
handleLoader(true);
147-
var outputContent;
148-
var urlDirectory = (dir === null) ? '/' : dir;
149-
150-
$.ajax({
151-
type: 'POST',
152-
url: '{{ route('server.files.directory-list', $server->uuidShort) }}',
153-
headers: { 'X-CSRF-Token': '{{ csrf_token() }}' },
154-
data: { directory: urlDirectory }
155-
}).done(function (data) {
156-
handleLoader(false);
157-
$("#load_files").slideUp(function () {
158-
$("#load_files").html(data).slideDown();
159-
$('[data-toggle="tooltip"]').tooltip();
160-
$('#internal_alert').slideUp();
161-
162-
// Run Actions Again
163-
reloadActions();
164-
});
165-
}).fail(function (jqXHR) {
166-
$("#internal_alert").html('<div class="alert alert-danger">An error occured while attempting to process this request. Please try again.</div>').show();
167-
console.log(jqXHR);
168-
});
169-
170-
}
171-
172-
// Load on Initial Page Load
173-
loadDirectoryContents($.urlParam('dir'));
174-
175-
});
72+
$(window).load(function () {
73+
$('.server-files').addClass('active');
74+
});
17675
</script>
17776
@endsection

resources/views/server/files/list.blade.php

Lines changed: 17 additions & 17 deletions
Original file line numberDiff line numberDiff line change
@@ -18,57 +18,57 @@
1818
{{-- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE --}}
1919
{{-- SOFTWARE. --}}
2020
<h4 class="nopad">/home/container{{ $directory['header'] }} &nbsp;<small><a href="/server/{{ $server->uuidShort }}/files/add/@if($directory['header'] !== '')?dir={{ $directory['header'] }}@endif" class="text-muted"><i class="fa fa-plus" data-toggle="tooltip" data-placement="top" title="Add New File(s)"></i></a></small></h4>
21-
<table class="table table-striped table-bordered table-hover">
21+
<table class="table table-striped table-bordered table-hover" id="file_listing">
2222
<thead>
2323
<tr>
2424
<th style="width:2%;text-align:center;"></th>
2525
<th style="width:45%">File Name</th>
2626
<th style="width:15%">Size</th>
2727
<th style="width:20%">Last Modified</th>
28-
<th style="width:20%;text-align:center;">Options</th>
28+
{{-- <th style="width:20%;text-align:center;">Options</th> --}}
2929
</tr>
3030
</thead>
3131
<tbody>
3232
@if (isset($directory['first']) && $directory['first'] === true)
3333
<tr>
3434
<td><i class="fa fa-folder-open" style="margin-left: 0.859px;"></i></td>
35-
<td><a href="/server/{{ $server->uuidShort }}/files" class="load_new">&larr;</a></a></td>
36-
<td></td>
35+
<td><a href="/server/{{ $server->uuidShort }}/files" data-action="directory-view">&larr;</a></a></td>
3736
<td></td>
3837
<td></td>
38+
{{-- <td></td> --}}
3939
</tr>
4040
@endif
4141
@if (isset($directory['show']) && $directory['show'] === true)
4242
<tr>
4343
<td><i class="fa fa-folder-open" style="margin-left: 0.859px;"></i></td>
44-
<td><a href="/server/{{ $server->uuidShort }}/files?dir={{ rawurlencode($directory['link']) }}" class="load_new">&larr; {{ $directory['link_show'] }}</a></a></td>
45-
<td></td>
44+
<td><a href="/server/{{ $server->uuidShort }}/files?dir={{ rawurlencode($directory['link']) }}" data-action="directory-view">&larr; {{ $directory['link_show'] }}</a></a></td>
4645
<td></td>
4746
<td></td>
47+
{{-- <td></td> --}}
4848
</tr>
4949
@endif
5050
@foreach ($folders as $folder)
51-
<tr>
52-
<td><i class="fa fa-folder-open" style="margin-left: 0.859px;"></i></td>
53-
<td><a href="/server/{{ $server->uuidShort }}/files?dir=/@if($folder['directory'] !== ''){{ rawurlencode($folder['directory']) }}/@endif{{ rawurlencode($folder['entry']) }}" class="load_new">{{ $folder['entry'] }}</a></td>
54-
<td>{{ $folder['size'] }}</td>
55-
<td>{{ date('m/d/y H:i:s', $folder['date']) }}</td>
56-
<td style="text-align:center;">
51+
<tr class="align-middle" data-path="@if($folder['directory'] !== ''){{ rawurlencode($folder['directory']) }}/@endif{{ rawurlencode($folder['entry']) }}">
52+
<td data-identifier="type"><i class="fa fa-folder-open" style="margin-left: 0.859px;"></i></td>
53+
<td data-identifier="name" data-hash="@if($folder['directory'] !== ''){{ rawurlencode($folder['directory']) }}/@endif{{ rawurlencode($folder['entry']) }}"><a href="/server/{{ $server->uuidShort }}/files" data-action="directory-view">{{ $folder['entry'] }}</a></td>
54+
<td data-identifier="size">{{ $folder['size'] }}</td>
55+
<td data-identifier="modified">{{ date('m/d/y H:i:s', $folder['date']) }}</td>
56+
{{-- <td class="text-center">
5757
<div class="row" style="text-align:center;">
5858
<div class="col-md-3 hidden-xs hidden-sm"></div>
5959
<div class="col-md-3 hidden-xs hidden-sm">
6060
</div>
6161
<div class="col-md-3">
6262
@can('delete-files', $server)
63-
<a href="@if($folder['directory'] !== ''){{ rawurlencode($folder['directory']) }}/@endif{{ rawurlencode($folder['entry']) }}" data-action="delete_file" data-name="{{ $folder['entry'] }}"><span class="badge label-danger"><i class="fa fa-trash-o"></i></span></a>
63+
<a href="@if($folder['directory'] !== ''){{ rawurlencode($folder['directory']) }}/@endif{{ rawurlencode($folder['entry']) }}" data-action="delete_file" data-name="{{ $folder['entry'] }}"><button class="btn btn-danger btn-xxs"><i class="fa fa-trash-o"></i></button></a>
6464
@endcan
6565
</div>
6666
</div>
67-
</td>
67+
</td> --}}
6868
</tr>
6969
@endforeach
7070
@foreach ($files as $file)
71-
<tr>
71+
<tr class="align-middle">
7272
<td><i class="fa fa-file-text" style="margin-left: 2px;"></i></td>
7373
<td>
7474
@if(in_array($file['extension'], $extensions))
@@ -83,7 +83,7 @@
8383
</td>
8484
<td>{{ $file['size'] }}</td>
8585
<td>{{ date('m/d/y H:i:s', $file['date']) }}</td>
86-
<td style="text-align:center;">
86+
{{-- <td style="text-align:center;">
8787
<div class="row" style="text-align:center;">
8888
<div class="col-md-3 hidden-xs hidden-sm">
8989
</div>
@@ -98,7 +98,7 @@
9898
@endcan
9999
</div>
100100
</div>
101-
</td>
101+
</td> --}}
102102
</tr>
103103
@endforeach
104104
</tbody>
Lines changed: 69 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,69 @@
1+
"use strict";
2+
3+
// Copyright (c) 2015 - 2016 Dane Everitt <dane@daneeveritt.com>
4+
//
5+
// Permission is hereby granted, free of charge, to any person obtaining a copy
6+
// of this software and associated documentation files (the "Software"), to deal
7+
// in the Software without restriction, including without limitation the rights
8+
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9+
// copies of the Software, and to permit persons to whom the Software is
10+
// furnished to do so, subject to the following conditions:
11+
//
12+
// The above copyright notice and this permission notice shall be included in all
13+
// copies or substantial portions of the Software.
14+
//
15+
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16+
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17+
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18+
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19+
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20+
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21+
// SOFTWARE.
22+
class FileActions {
23+
constructor() {
24+
//
25+
}
26+
27+
run() {
28+
this.directoryClick();
29+
this.rightClick();
30+
}
31+
32+
rightClick() {
33+
$('#file_listing > tbody').on('contextmenu', event => {
34+
event.preventDefault();
35+
const parent = $(event.target).parent();
36+
37+
$('#fileOptionMenu').appendTo('body');
38+
$('#fileOptionMenu').data('invokedOn', $(event.target)).show().css({
39+
position: 'absolute',
40+
left: event.pageX,
41+
top: event.pageY,
42+
});
43+
44+
// Handle Events
45+
var Context = new ContextMenuActions(parent);
46+
$('#fileOptionMenu li[data-action="move"]').unbind().on('click', e => {
47+
Context.move();
48+
});
49+
50+
$('#fileOptionMenu li[data-action="rename"]').unbind().on('click', e => {
51+
Context.rename();
52+
});
53+
54+
$(window).click(() => {
55+
$('#fileOptionMenu').hide();
56+
});
57+
});
58+
}
59+
60+
directoryClick() {
61+
$('a[data-action="directory-view"]').on('click', function (event) {
62+
event.preventDefault();
63+
window.location.hash = encodeURIComponent($(this).parent().data('hash') || '');
64+
Files.list();
65+
});
66+
}
67+
}
68+
69+
window.Actions = new FileActions;

0 commit comments

Comments
 (0)