Project manager improvements
- Faster launch time by loading icons in a coroutine - Faster sorting, filtering, fav'ing etc - Refactored project list with a proper structured class
This commit is contained in:
parent
0bf930c117
commit
d3652887df
2 changed files with 874 additions and 565 deletions
File diff suppressed because it is too large
Load diff
|
@ -39,6 +39,7 @@
|
||||||
#include "scene/gui/tree.h"
|
#include "scene/gui/tree.h"
|
||||||
|
|
||||||
class ProjectDialog;
|
class ProjectDialog;
|
||||||
|
class ProjectList;
|
||||||
class ProjectListFilter;
|
class ProjectListFilter;
|
||||||
|
|
||||||
class ProjectManager : public Control {
|
class ProjectManager : public Control {
|
||||||
|
@ -68,16 +69,13 @@ class ProjectManager : public Control {
|
||||||
AcceptDialog *dialog_error;
|
AcceptDialog *dialog_error;
|
||||||
ProjectDialog *npdialog;
|
ProjectDialog *npdialog;
|
||||||
|
|
||||||
ScrollContainer *scroll;
|
|
||||||
VBoxContainer *scroll_children;
|
|
||||||
HBoxContainer *projects_hb;
|
HBoxContainer *projects_hb;
|
||||||
TabContainer *tabs;
|
TabContainer *tabs;
|
||||||
|
ProjectList *_project_list;
|
||||||
|
|
||||||
OptionButton *language_btn;
|
OptionButton *language_btn;
|
||||||
Control *gui_base;
|
Control *gui_base;
|
||||||
|
|
||||||
Map<String, String> selected_list; // name -> main_scene
|
|
||||||
String last_clicked;
|
|
||||||
bool importing;
|
bool importing;
|
||||||
|
|
||||||
void _open_asset_library();
|
void _open_asset_library();
|
||||||
|
@ -86,7 +84,6 @@ class ProjectManager : public Control {
|
||||||
void _run_project_confirm();
|
void _run_project_confirm();
|
||||||
void _open_selected_projects();
|
void _open_selected_projects();
|
||||||
void _open_selected_projects_ask();
|
void _open_selected_projects_ask();
|
||||||
void _show_project(const String &p_path);
|
|
||||||
void _import_project();
|
void _import_project();
|
||||||
void _new_project();
|
void _new_project();
|
||||||
void _rename_project();
|
void _rename_project();
|
||||||
|
@ -111,13 +108,13 @@ class ProjectManager : public Control {
|
||||||
void _install_project(const String &p_zip_path, const String &p_title);
|
void _install_project(const String &p_zip_path, const String &p_title);
|
||||||
|
|
||||||
void _dim_window();
|
void _dim_window();
|
||||||
void _panel_draw(Node *p_hb);
|
|
||||||
void _panel_input(const Ref<InputEvent> &p_ev, Node *p_hb);
|
|
||||||
void _unhandled_input(const Ref<InputEvent> &p_ev);
|
void _unhandled_input(const Ref<InputEvent> &p_ev);
|
||||||
void _favorite_pressed(Node *p_hb);
|
|
||||||
void _files_dropped(PoolStringArray p_files, int p_screen);
|
void _files_dropped(PoolStringArray p_files, int p_screen);
|
||||||
void _scan_multiple_folders(PoolStringArray p_files);
|
void _scan_multiple_folders(PoolStringArray p_files);
|
||||||
|
|
||||||
|
void _on_order_option_changed();
|
||||||
|
void _on_filter_option_changed();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void _notification(int p_what);
|
void _notification(int p_what);
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
|
|
Loading…
Reference in a new issue