mirror of
				https://github.com/pelican-dev/panel.git
				synced 2025-10-26 16:36:51 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			188 lines
		
	
	
		
			7.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			188 lines
		
	
	
		
			7.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| {{-- 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. --}}
 | |
| @extends('layouts.master')
 | |
| 
 | |
| @section('title')
 | |
|     Managing Files for: {{ $server->name }}
 | |
| @endsection
 | |
| 
 | |
| @section('scripts')
 | |
|     @parent
 | |
|     {!! Theme::js('js/vendor/async/async.min.js') !!}
 | |
|     {!! Theme::js('js/vendor/lodash/lodash.js') !!}
 | |
|     {!! Theme::js('js/vendor/upload/client.min.js') !!}
 | |
| @endsection
 | |
| 
 | |
| @section('content')
 | |
| <div class="col-md-12">
 | |
|     <div class="row">
 | |
|         <div class="col-md-12" id="internal_alert">
 | |
|             <div class="alert alert-info">
 | |
|                 <i class="fa fa-spinner fa-spin"></i> {{ trans('server.files.loading') }}
 | |
|             </div>
 | |
|         </div>
 | |
|     </div>
 | |
|     <div class="row">
 | |
|         <div class="col-md-12">
 | |
|             <div class="ajax_loading_box"><i class="fa fa-refresh fa-spin" id="position_me"></i></div>
 | |
|         </div>
 | |
|     </div>
 | |
|     <div class="row" id="upload_box">
 | |
|         <div class="col-md-12" id="load_files"></div>
 | |
|         <div class="col-md-12">
 | |
|             <div class="panel panel-default">
 | |
|                 <div class="panel-heading">
 | |
|                     <h3 class="panel-title">File Path Information</h3>
 | |
|                 </div>
 | |
|                 <div class="panel-body">
 | |
|                     When configuring any file paths in your server plugins or settings you should use <code>/home/container</code> as your base path.
 | |
|                 </div>
 | |
|             </div>
 | |
|         </div>
 | |
|     </div>
 | |
| </div>
 | |
| <script src="{{ route('server.js', [$server->uuidShort, 'filemanager', 'index.js']) }}"></script>
 | |
| <script src="{{ route('server.js', [$server->uuidShort, 'filemanager', 'contextmenu.js']) }}"></script>
 | |
| <script src="{{ route('server.js', [$server->uuidShort, 'filemanager', 'actions.js']) }}"></script>
 | |
| <script>
 | |
| $(window).load(function () {
 | |
|     $('.server-files').addClass('active');
 | |
|     @can('upload-files', $server)
 | |
|         var notifyUploadSocketError = false;
 | |
|         var uploadSocket = io('{{ $node->scheme }}://{{ $node->fqdn }}:{{ $node->daemonListen }}/upload/{{ $server->uuid }}', {
 | |
|             'query': 'token={{ $server->daemonSecret }}'
 | |
|         });
 | |
| 
 | |
|         socket.io.on('connect_error', function (err) {
 | |
|             siofu.destroy();
 | |
|             $('#applyUpdate').removeClass('fa-circle-o-notch fa-spinner fa-spin').addClass('fa-question-circle').css({ color: '#FF9900' });
 | |
|             if(typeof notifyUploadSocketError !== 'object') {
 | |
|                 notifyUploadSocketError = $.notify({
 | |
|                     message: 'There was an error connecting to the Upload Socket for this server.'
 | |
|                 }, {
 | |
|                     type: 'danger',
 | |
|                     delay: 0
 | |
|                 });
 | |
|             }
 | |
|         });
 | |
| 
 | |
|         uploadSocket.on('error', err => {
 | |
|             siofu.destroy();
 | |
|             console.error(err);
 | |
|         });
 | |
| 
 | |
|         uploadSocket.on('connect', function () {
 | |
|             if (notifyUploadSocketError !== false) {
 | |
|                 notifyUploadSocketError.close();
 | |
|                 notifyUploadSocketError = false;
 | |
|             }
 | |
|         });
 | |
| 
 | |
|         socket.on('error', function (err) {
 | |
|             console.error('There was an error while attemping to connect to the websocket: ' + err + '\n\nPlease try loading this page again.');
 | |
|         });
 | |
| 
 | |
| 
 | |
|         var siofu = new SocketIOFileUpload(uploadSocket);
 | |
|         siofu.chunkDelay = 25;
 | |
| 
 | |
|         siofu.listenOnDrop(document.getElementById("upload_box"));
 | |
| 
 | |
|         window.addEventListener('dragover', function (event) {
 | |
|             event.preventDefault();
 | |
|         }, false);
 | |
| 
 | |
|         window.addEventListener('drop', function (event) {
 | |
|             event.preventDefault();
 | |
|         }, false);
 | |
| 
 | |
|         var dropCounter = 0;
 | |
|         $('#upload_box').bind({
 | |
|             dragenter: function (event) {
 | |
|                 event.preventDefault();
 | |
|                 dropCounter++;
 | |
|                 $(this).addClass('hasFileHover');
 | |
|             },
 | |
|             dragleave: function (event) {
 | |
|                 dropCounter--;
 | |
|                 if (dropCounter === 0) {
 | |
|                     $(this).removeClass('hasFileHover');
 | |
|                 }
 | |
|             },
 | |
|             drop: function (event) {
 | |
|                 dropCounter = 0;
 | |
|                 $(this).removeClass('hasFileHover');
 | |
|             }
 | |
|         });
 | |
| 
 | |
|         siofu.addEventListener('start', function (event) {
 | |
|             event.file.meta.path = $('#headerTableRow').attr('data-currentdir');
 | |
|             event.file.meta.identifier = Math.random().toString(36).slice(2);
 | |
| 
 | |
|             $('#append_files_to').append('<tr id="file-upload-' + event.file.meta.identifier +'"> \
 | |
|                 <td><i class="fa fa-file-text-o" style="margin-left: 2px;"></i></td> \
 | |
|                 <td>' + event.file.name + '</td> \
 | |
|                 <td colspan=2"> </td> \
 | |
|             </tr><tr> \
 | |
|                 <td colspan="4" class="has-progress"> \
 | |
|                     <div class="progress progress-table-bottom active"> \
 | |
|                         <div class="progress-bar progress-bar-info prog-bar-' + event.file.meta.identifier +'" style="width: 0%"></div> \
 | |
|                     </div> \
 | |
|                 </td> \
 | |
|             </tr>\
 | |
|             ');
 | |
|         });
 | |
| 
 | |
|         siofu.addEventListener('progress', function(event) {
 | |
|             var percent = event.bytesLoaded / event.file.size * 100;
 | |
|             if (percent >= 100) {
 | |
|                 $('.prog-bar-' + event.file.meta.identifier).css('width', '100%').removeClass('progress-bar-info').addClass('progress-bar-success').parent().removeClass('active');
 | |
|             } else {
 | |
|                 $('.prog-bar-' + event.file.meta.identifier).css('width', percent + '%');
 | |
|             }
 | |
|         });
 | |
| 
 | |
|         // Do something when a file is uploaded:
 | |
|         siofu.addEventListener('complete', function(event){
 | |
|             if (!event.success) {
 | |
|                 $('.prog-bar-' + event.file.meta.identifier).css('width', '100%').removeClass('progress-bar-info').addClass('progress-bar-danger');
 | |
|                 $.notify({
 | |
|                     message: 'An error was encountered while attempting to upload this file.'
 | |
|                 }, {
 | |
|                     type: 'danger',
 | |
|                     delay: 5000
 | |
|                 });
 | |
|             }
 | |
|         });
 | |
| 
 | |
|         siofu.addEventListener('error', function(event){
 | |
|             $('.prog-bar-' + event.file.meta.identifier).css('width', '100%').removeClass('progress-bar-info').addClass('progress-bar-danger');
 | |
|             $.notify({
 | |
|                 message: 'An error was encountered while attempting to upload this file.'
 | |
|             }, {
 | |
|                 type: 'danger',
 | |
|                 delay: 5000
 | |
|             });
 | |
|         });
 | |
|     @endcan
 | |
| });
 | |
| </script>
 | |
| @endsection
 | 
