mirror of
https://github.com/xevidos/codiad.git
synced 2025-01-03 11:42:12 +01:00
Continued work on cleaning up filemanager basic functions
This commit is contained in:
parent
0cf5797fd5
commit
04f537aeee
2 changed files with 158 additions and 21 deletions
|
@ -3,13 +3,13 @@
|
||||||
"title": "New File",
|
"title": "New File",
|
||||||
"icon": "icon-doc-text",
|
"icon": "icon-doc-text",
|
||||||
"applies-to" : "directory-only",
|
"applies-to" : "directory-only",
|
||||||
"onclick": "codiad.filemanager.createNode($('#context-menu').attr('data-path'),'file');"
|
"onclick": "codiad.filemanager.create_node($('#context-menu').attr('data-path'),'file');"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "New Folder",
|
"title": "New Folder",
|
||||||
"icon": "icon-folder",
|
"icon": "icon-folder",
|
||||||
"applies-to" : "directory-only",
|
"applies-to" : "directory-only",
|
||||||
"onclick": "codiad.filemanager.createNode($('#context-menu').attr('data-path'),'directory');"
|
"onclick": "codiad.filemanager.create_node($('#context-menu').attr('data-path'),'directory');"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"title": "Break",
|
"title": "Break",
|
||||||
|
|
|
@ -132,7 +132,7 @@
|
||||||
console.log( _this.post_max_size );
|
console.log( _this.post_max_size );
|
||||||
},
|
},
|
||||||
|
|
||||||
context_menu_track_mouse: function() {
|
context_menu_track_mouse: function( e ) {
|
||||||
|
|
||||||
let _this = codiad.filemanager;
|
let _this = codiad.filemanager;
|
||||||
let offset = $( '#context-menu' ).offset();
|
let offset = $( '#context-menu' ).offset();
|
||||||
|
@ -403,6 +403,38 @@
|
||||||
return path.split( '.' ).pop();
|
return path.split( '.' ).pop();
|
||||||
},
|
},
|
||||||
|
|
||||||
|
get_index: function( path, files ) {
|
||||||
|
|
||||||
|
let _this = codiad.filemanager;
|
||||||
|
|
||||||
|
return new Promise( async function( resolve, reject ) {
|
||||||
|
|
||||||
|
let index = {};
|
||||||
|
let total = ( !!files ) ? files.length : 0;
|
||||||
|
|
||||||
|
for( let i = 0;i < total;i++ ) {
|
||||||
|
|
||||||
|
if( path == files[i].dirname ) {
|
||||||
|
|
||||||
|
index = files[i];
|
||||||
|
break;
|
||||||
|
} else {
|
||||||
|
|
||||||
|
if( files[i].children !== undefined ) {
|
||||||
|
|
||||||
|
index = await _this.get_index( path, files[i].children );
|
||||||
|
|
||||||
|
if( Object.keys( index ).length > 0 ) {
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
resolve( index );
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
get_indexes: async function( path ) {
|
get_indexes: async function( path ) {
|
||||||
|
|
||||||
let r = await $.get( this.controller + '?action=index&path=' + encodeURIComponent( path ) );
|
let r = await $.get( this.controller + '?action=index&path=' + encodeURIComponent( path ) );
|
||||||
|
@ -466,11 +498,17 @@
|
||||||
let root = false;
|
let root = false;
|
||||||
let span = node.prev();
|
let span = node.prev();
|
||||||
let total_saved = _this.files.length;
|
let total_saved = _this.files.length;
|
||||||
|
let file = await _this.get_index( path );
|
||||||
rescan = !!rescan;
|
rescan = !!rescan;
|
||||||
|
|
||||||
node.addClass( 'loading' );
|
node.addClass( 'loading' );
|
||||||
|
|
||||||
|
if( Object.keys( file ).length == 0 ) {
|
||||||
|
|
||||||
|
children = file.children;
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log( file.children, file )
|
||||||
if( rescan || total_saved == 0 || ! children ) {
|
if( rescan || total_saved == 0 || ! children ) {
|
||||||
|
|
||||||
let data = await _this.get_indexes( path );
|
let data = await _this.get_indexes( path );
|
||||||
|
@ -496,7 +534,7 @@
|
||||||
files = file.children;
|
files = file.children;
|
||||||
}
|
}
|
||||||
|
|
||||||
files = _this.get_opened_indexes( files );
|
files = await _this.get_opened_indexes( files );
|
||||||
_this.index_nodes(
|
_this.index_nodes(
|
||||||
path,
|
path,
|
||||||
node,
|
node,
|
||||||
|
@ -513,6 +551,7 @@
|
||||||
path: path,
|
path: path,
|
||||||
files: files
|
files: files
|
||||||
});
|
});
|
||||||
|
return true;
|
||||||
},
|
},
|
||||||
|
|
||||||
index_directory_callback: function( entry, container, i, files ) {
|
index_directory_callback: function( entry, container, i, files ) {
|
||||||
|
@ -560,7 +599,7 @@
|
||||||
|
|
||||||
if( v.type == "file" ) {
|
if( v.type == "file" ) {
|
||||||
|
|
||||||
if( filters.type == "directories" ) {
|
if( filters.type == "directory" ) {
|
||||||
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -572,6 +611,11 @@
|
||||||
|
|
||||||
} else if( v.type == "directory" ) {
|
} else if( v.type == "directory" ) {
|
||||||
|
|
||||||
|
if( filters.type == "file" ) {
|
||||||
|
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if( v.children ) {
|
if( v.children ) {
|
||||||
|
|
||||||
if( v.open ) {
|
if( v.open ) {
|
||||||
|
@ -583,9 +627,14 @@
|
||||||
node_class = "plus";
|
node_class = "plus";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
name = v.basename;
|
||||||
|
type = 'directory';
|
||||||
}
|
}
|
||||||
|
|
||||||
span.addClass( nodeClass );
|
console.log( v.path, v.type );
|
||||||
|
|
||||||
|
span.addClass( node_class );
|
||||||
link.addClass( type );
|
link.addClass( type );
|
||||||
link.attr( "data-type", type );
|
link.attr( "data-type", type );
|
||||||
link.attr( "data-path", v.path );
|
link.attr( "data-path", v.path );
|
||||||
|
@ -625,7 +674,7 @@
|
||||||
ul.replaceWith( container );
|
ul.replaceWith( container );
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
$( container ).insertAfter( node );
|
container.insertAfter( node );
|
||||||
}
|
}
|
||||||
|
|
||||||
node.removeClass( 'loading' );
|
node.removeClass( 'loading' );
|
||||||
|
@ -654,10 +703,10 @@
|
||||||
|
|
||||||
if( $( this ).hasClass( 'directory' ) ) {
|
if( $( this ).hasClass( 'directory' ) ) {
|
||||||
|
|
||||||
_this.index( $( this ).attr( 'data-path' ) );
|
_this.toggle_directory( $( this ).attr( 'data-path' ) );
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
_this.openFile( $( this ).attr( 'data-path' ) );
|
_this.open_file( $( this ).attr( 'data-path' ) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
@ -666,7 +715,7 @@
|
||||||
// Open or Expand
|
// Open or Expand
|
||||||
if( $( this ).parent().children( "a" ).attr( 'data-type' ) == 'directory' ) {
|
if( $( this ).parent().children( "a" ).attr( 'data-type' ) == 'directory' ) {
|
||||||
|
|
||||||
_this.index( $( this ).parent().children( "a" ).attr( 'data-path' ) );
|
_this.toggle_directory( $( this ).parent().children( "a" ).attr( 'data-path' ) );
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
_this.openFile( $( this ).parent().children( "a" ).attr( 'data-path' ) );
|
_this.openFile( $( this ).parent().children( "a" ).attr( 'data-path' ) );
|
||||||
|
@ -691,10 +740,10 @@
|
||||||
|
|
||||||
if( $( this ).hasClass( 'directory' ) ) {
|
if( $( this ).hasClass( 'directory' ) ) {
|
||||||
|
|
||||||
_this.index( $( this ).attr( 'data-path' ) );
|
_this.toggle_directory( $( this ).attr( 'data-path' ) );
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
_this.openFile( $( this ).attr( 'data-path' ) );
|
_this.open_file( $( this ).attr( 'data-path' ) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
@ -710,7 +759,7 @@
|
||||||
|
|
||||||
let _this = codiad.filemanager;
|
let _this = codiad.filemanager;
|
||||||
let node = $( '#file-manager a[data-path="' + path + '"]' );
|
let node = $( '#file-manager a[data-path="' + path + '"]' );
|
||||||
let ext = _this.getExtension( path );
|
let ext = _this.get_extension( path );
|
||||||
|
|
||||||
if( $.inArray( ext.toLowerCase(), _this.noOpen ) < 0 ) {
|
if( $.inArray( ext.toLowerCase(), _this.noOpen ) < 0 ) {
|
||||||
|
|
||||||
|
@ -768,7 +817,7 @@
|
||||||
|
|
||||||
rename_node: function( path, new_path ) {
|
rename_node: function( path, new_path ) {
|
||||||
|
|
||||||
let shortName = this.getShortName( path );
|
let shortName = this.get_short_name( path );
|
||||||
let type = this.getType( path );
|
let type = this.getType( path );
|
||||||
let _this = this;
|
let _this = this;
|
||||||
let project = codiad.project.getCurrent();
|
let project = codiad.project.getCurrent();
|
||||||
|
@ -883,6 +932,95 @@
|
||||||
return index;
|
return index;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
set_index: function( path, files, data ) {
|
||||||
|
|
||||||
|
let _this = codiad.filemanager;
|
||||||
|
let index = false;
|
||||||
|
let total = ( !!files ) ? files.length : 0;
|
||||||
|
|
||||||
|
for( let i = 0;i < total;i++ ) {
|
||||||
|
|
||||||
|
if( path == files[i].dirname ) {
|
||||||
|
|
||||||
|
files[i] = data;
|
||||||
|
index = files[i];
|
||||||
|
break;
|
||||||
|
} else {
|
||||||
|
|
||||||
|
if( files[i].children !== undefined ) {
|
||||||
|
|
||||||
|
index = _this.set_index( path, files[i].children, data );
|
||||||
|
|
||||||
|
if( index ) {
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return index;
|
||||||
|
},
|
||||||
|
|
||||||
|
toggle_directory: async function( path, open_callback, close_callback ) {
|
||||||
|
|
||||||
|
let _this = codiad.filemanager;
|
||||||
|
let node = $( '#file-manager a[data-path="' + path + '"]' );
|
||||||
|
|
||||||
|
node.addClass( "loading" );
|
||||||
|
|
||||||
|
let i = await _this.get_index( path, _this.files );
|
||||||
|
let span = node.parent().children( 'span' );
|
||||||
|
let link = node.parent().children( 'a' );
|
||||||
|
|
||||||
|
console.log( i );
|
||||||
|
|
||||||
|
if( Object.keys( i ).length == 0 ) {
|
||||||
|
|
||||||
|
let result = await _this.index( path );
|
||||||
|
i = {
|
||||||
|
open: false,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if( i.open ) {
|
||||||
|
|
||||||
|
node.parent().children( 'ul' )
|
||||||
|
.slideUp( 300, function() {
|
||||||
|
|
||||||
|
$( this ).remove();
|
||||||
|
|
||||||
|
span.removeClass( 'minus' );
|
||||||
|
node.removeClass( 'open' );
|
||||||
|
|
||||||
|
span.addClass( 'plus' );
|
||||||
|
|
||||||
|
if( typeof close_callback == "function" ) {
|
||||||
|
|
||||||
|
close_callback();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
if( typeof open_callback == "function" ) {
|
||||||
|
|
||||||
|
close_callback( node );
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
|
||||||
|
span.removeClass( 'plus' );
|
||||||
|
|
||||||
|
span.addClass( 'minus' );
|
||||||
|
link.addClass( 'open' );
|
||||||
|
|
||||||
|
_this.index( path );
|
||||||
|
}
|
||||||
|
|
||||||
|
i.open = !i.open
|
||||||
|
_this.set_index( path, _this.files, i );
|
||||||
|
|
||||||
|
console.log( i, await _this.get_index( path, _this.files ) );
|
||||||
|
node.removeClass( "loading" );
|
||||||
|
},
|
||||||
|
|
||||||
unarchive: function( path ) {
|
unarchive: function( path ) {
|
||||||
|
|
||||||
let _this = this;
|
let _this = this;
|
||||||
|
@ -903,13 +1041,12 @@
|
||||||
//Compatibility functions
|
//Compatibility functions
|
||||||
|
|
||||||
copyNode: this.copy_node,
|
copyNode: this.copy_node,
|
||||||
createNode: this.create_node,
|
createNode: function( path, type ) {return this.create_node( path, type )},
|
||||||
createObject: this.create_object,
|
|
||||||
deleteNode: this.delete_node,
|
deleteNode: this.delete_node,
|
||||||
getExtension: this.get_extension,
|
getExtension: function( path ) {return this.create_node( path )},
|
||||||
getShortName: this.get_short_name,
|
getShortName: function( path ) {return this.get_short_name( path )},
|
||||||
getType: this.get_type,
|
getType: function( path ) {return this.get_type( path )},
|
||||||
openFile: this.open_file,
|
openFile: function( path ) {return this.open_file( path )},
|
||||||
openInBrowser: this.preview,
|
openInBrowser: this.preview,
|
||||||
pasteNode: this.paste_node,
|
pasteNode: this.paste_node,
|
||||||
renameNode: this.rename_node,
|
renameNode: this.rename_node,
|
||||||
|
|
Loading…
Reference in a new issue