mirror of
				https://github.com/pelican-dev/panel.git
				synced 2025-10-25 15:26:52 +02:00 
			
		
		
		
	redesign parts of the file manager
ignore yarn.lock file
This commit is contained in:
		
							parent
							
								
									0c1559c922
								
							
						
					
					
						commit
						c62312b8af
					
				
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -10,3 +10,4 @@ Vagrantfile | |||||||
| Vagrantfile | Vagrantfile | ||||||
| 
 | 
 | ||||||
| node_modules | node_modules | ||||||
|  | yarn.lock | ||||||
|  | |||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -29,15 +29,22 @@ class ActionsClass { | |||||||
|         this.element = undefined; |         this.element = undefined; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     folder() { |     folder(path) { | ||||||
|  |         let inputValue | ||||||
|  |         if (path) { | ||||||
|  |             inputValue = path | ||||||
|  |         } else { | ||||||
|             const nameBlock = $(this.element).find('td[data-identifier="name"]'); |             const nameBlock = $(this.element).find('td[data-identifier="name"]'); | ||||||
|         const currentName = decodeURIComponent(nameBlock.attr('data-name')); |             const currentName = decodeURIComponent(nameBlock.data('name')); | ||||||
|             const currentPath = decodeURIComponent(nameBlock.data('path')); |             const currentPath = decodeURIComponent(nameBlock.data('path')); | ||||||
| 
 | 
 | ||||||
|         let inputValue = `${currentPath}${currentName}/`; |  | ||||||
|             if ($(this.element).data('type') === 'file') { |             if ($(this.element).data('type') === 'file') { | ||||||
|                 inputValue = currentPath; |                 inputValue = currentPath; | ||||||
|  |             } else { | ||||||
|  |                 inputValue = `${currentPath}${currentName}/`; | ||||||
|             } |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         swal({ |         swal({ | ||||||
|             type: 'input', |             type: 'input', | ||||||
|             title: 'Create Folder', |             title: 'Create Folder', | ||||||
|  | |||||||
| @ -33,7 +33,7 @@ class ContextMenuClass { | |||||||
|         $(document).find('#fileOptionMenu').remove(); |         $(document).find('#fileOptionMenu').remove(); | ||||||
|         if (!_.isNull(this.activeLine)) this.activeLine.removeClass('active'); |         if (!_.isNull(this.activeLine)) this.activeLine.removeClass('active'); | ||||||
| 
 | 
 | ||||||
|         let newFilePath = $('#headerTableRow').attr('data-currentDir'); |         let newFilePath = $('#file_listing').data('current-dir'); | ||||||
|         if (parent.data('type') === 'folder') { |         if (parent.data('type') === 'folder') { | ||||||
|             const nameBlock = parent.find('td[data-identifier="name"]'); |             const nameBlock = parent.find('td[data-identifier="name"]'); | ||||||
|             const currentName = decodeURIComponent(nameBlock.attr('data-name')); |             const currentName = decodeURIComponent(nameBlock.attr('data-name')); | ||||||
|  | |||||||
| @ -44,6 +44,7 @@ class FileManager { | |||||||
|             $('#load_files').slideUp(10).html(data).slideDown(10, () => { |             $('#load_files').slideUp(10).html(data).slideDown(10, () => { | ||||||
|                 ContextMenu.run(); |                 ContextMenu.run(); | ||||||
|                 this.reloadFilesButton(); |                 this.reloadFilesButton(); | ||||||
|  |                 this.addFolderButton(); | ||||||
|                 if (_.isFunction(next)) { |                 if (_.isFunction(next)) { | ||||||
|                     return next(); |                     return next(); | ||||||
|                 } |                 } | ||||||
| @ -82,6 +83,12 @@ class FileManager { | |||||||
|         }); |         }); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     addFolderButton() { | ||||||
|  |         $('i[data-action="add-folder"]').unbind().on('click', () => { | ||||||
|  |             new ActionsClass().folder($('#file_listing').data('current-dir') || '/'); | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     decodeHash() { |     decodeHash() { | ||||||
|         return decodeURIComponent(window.location.hash.substring(1)); |         return decodeURIComponent(window.location.hash.substring(1)); | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -84,7 +84,7 @@ | |||||||
|         window.onbeforeunload = function () { |         window.onbeforeunload = function () { | ||||||
|             return 'A file upload in in progress, are you sure you want to continue?'; |             return 'A file upload in in progress, are you sure you want to continue?'; | ||||||
|         }; |         }; | ||||||
|         event.file.meta.path = $('#headerTableRow').attr('data-currentdir'); |         event.file.meta.path = $('#file_listing').data('current-dir'); | ||||||
|         event.file.meta.identifier = Math.random().toString(36).slice(2); |         event.file.meta.identifier = Math.random().toString(36).slice(2); | ||||||
| 
 | 
 | ||||||
|         $('#append_files_to').append('<tr id="file-upload-' + event.file.meta.identifier +'"> \ |         $('#append_files_to').append('<tr id="file-upload-' + event.file.meta.identifier +'"> \ | ||||||
|  | |||||||
| @ -212,6 +212,7 @@ return [ | |||||||
|         'size' => 'Size', |         'size' => 'Size', | ||||||
|         'last_modified' => 'Last Modified', |         'last_modified' => 'Last Modified', | ||||||
|         'add_new' => 'Add New File', |         'add_new' => 'Add New File', | ||||||
|  |         'add_folder' => 'Add New Folder', | ||||||
|         'edit' => [ |         'edit' => [ | ||||||
|             'header' => 'Edit File', |             'header' => 'Edit File', | ||||||
|             'header_sub' => 'Make modifications to a file from the web.', |             'header_sub' => 'Make modifications to a file from the web.', | ||||||
|  | |||||||
| @ -38,9 +38,11 @@ | |||||||
|     <div class="col-xs-12"> |     <div class="col-xs-12"> | ||||||
|         <div class="box box-primary"> |         <div class="box box-primary"> | ||||||
|             <div class="overlay file-overlay"><i class="fa fa-refresh fa-spin"></i></div> |             <div class="overlay file-overlay"><i class="fa fa-refresh fa-spin"></i></div> | ||||||
|             <div class="box-body table-responsive no-padding" id="load_files"> |             <div id="load_files"> | ||||||
|  |                 <div class="box-body table-responsive no-padding"> | ||||||
|                     <div class="callout callout-info" style="margin:10px;">@lang('server.files.loading')</div> |                     <div class="callout callout-info" style="margin:10px;">@lang('server.files.loading')</div> | ||||||
|                 </div> |                 </div> | ||||||
|  |             </div> | ||||||
|             <div class="box-footer with-border"> |             <div class="box-footer with-border"> | ||||||
|                 <p class="text-muted small" style="margin: 0 0 2px;">@lang('server.files.path', ['path' => '<code>/home/container</code>', 'size' => '<code>' . $node->upload_size . ' MB</code>'])</p> |                 <p class="text-muted small" style="margin: 0 0 2px;">@lang('server.files.path', ['path' => '<code>/home/container</code>', 'size' => '<code>' . $node->upload_size . ' MB</code>'])</p> | ||||||
|             </div> |             </div> | ||||||
|  | |||||||
| @ -17,29 +17,31 @@ | |||||||
| {{-- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, --}} | {{-- 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 --}} | {{-- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE --}} | ||||||
| {{-- SOFTWARE. --}} | {{-- SOFTWARE. --}} | ||||||
| <table class="table table-hover" id="file_listing"> | 
 | ||||||
|  | <div class="box-header"> | ||||||
|  |     <i class="fa fa-refresh muted muted-hover use-pointer" data-action="reload-files"></i> | ||||||
|  |     <code class="box-title">/home/container{{ $directory['header'] }}</code> | ||||||
|  |     <a class="text-muted"> | ||||||
|  |         <i class="fa fa-plus" data-action="add-folder" data-toggle="tooltip" data-placement="top" title="@lang('server.files.add_folder')"></i> | ||||||
|  |     </a> | ||||||
|  |     <div class="box-tools pull-right"> | ||||||
|  |         <a class="btn btn-primary btn-sm" href="/server/{{ $server->uuidShort }}/files/add/@if($directory['header'] !== '')?dir={{ $directory['header'] }}@endif"> | ||||||
|  |             <i class="fa fa-file"></i> Create File | ||||||
|  |         </a> | ||||||
|  |         <a class="btn btn-primary btn-sm btn-icon btn-file"> | ||||||
|  |             <i class="fa fa-upload"></i> Upload <input type="file" id="files_touch_target" style="display: none;"> | ||||||
|  |         </a> | ||||||
|  |     </div> | ||||||
|  | </div> | ||||||
|  | <div class="box-body table-responsive no-padding"> | ||||||
|  |     <table class="table table-hover" id="file_listing" data-current-dir="{{ $directory['header'] }}"> | ||||||
|         <thead> |         <thead> | ||||||
|             <tr> |             <tr> | ||||||
|             <th style="width:2%;text-align:center;" class="middle"><i class="fa fa-refresh muted muted-hover use-pointer" data-action="reload-files"></i></th> |                 <th style="width:2%;" class="middle"></th> | ||||||
|                 <th style="width:55%">@lang('server.files.file_name')</th> |                 <th style="width:55%">@lang('server.files.file_name')</th> | ||||||
|                 <th style="width:15%" class="hidden-xs">@lang('server.files.size')</th> |                 <th style="width:15%" class="hidden-xs">@lang('server.files.size')</th> | ||||||
|                 <th style="width:20%" class="hidden-xs">@lang('server.files.last_modified')</th> |                 <th style="width:20%" class="hidden-xs">@lang('server.files.last_modified')</th> | ||||||
|             <th style="width:8%"> |                 <th style="width:8%"></th> | ||||||
|                 <label class="btn btn-primary btn-xs btn-file"> |  | ||||||
|                     Upload <input type="file" id="files_touch_target" style="display: none;"/> |  | ||||||
|                 </label> |  | ||||||
|             </th> |  | ||||||
|         </tr> |  | ||||||
|         <tr id="headerTableRow" data-currentdir="{{ $directory['header'] }}"> |  | ||||||
|             <th><i class="fa fa-folder-open"></i></th> |  | ||||||
|             <th colspan="4"> |  | ||||||
|                 <code>/home/container{{ $directory['header'] }}</code> |  | ||||||
|                 <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="@lang('server.files.add_new')"></i> |  | ||||||
|                     </a> |  | ||||||
|                 </small> |  | ||||||
|             </th> |  | ||||||
|             </tr> |             </tr> | ||||||
|         </thead> |         </thead> | ||||||
|         <tbody id="append_files_to"> |         <tbody id="append_files_to"> | ||||||
| @ -161,4 +163,5 @@ | |||||||
|                 </tr> |                 </tr> | ||||||
|             @endforeach |             @endforeach | ||||||
|         </tbody> |         </tbody> | ||||||
| </table> |     </table> | ||||||
|  | </div> | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Jakob Schrettenbrunner
						Jakob Schrettenbrunner