Improve plugin dialog UX
This commit is contained in:
parent
563690347a
commit
32c4d110eb
@ -200,12 +200,9 @@ EditorPluginSettings::EditorPluginSettings() {
|
|||||||
l->set_theme_type_variation("HeaderSmall");
|
l->set_theme_type_variation("HeaderSmall");
|
||||||
title_hb->add_child(l);
|
title_hb->add_child(l);
|
||||||
title_hb->add_spacer();
|
title_hb->add_spacer();
|
||||||
create_plugin = memnew(Button(TTR("Create")));
|
Button *create_plugin = memnew(Button(TTR("Create New Plugin")));
|
||||||
create_plugin->connect("pressed", callable_mp(this, &EditorPluginSettings::_create_clicked));
|
create_plugin->connect("pressed", callable_mp(this, &EditorPluginSettings::_create_clicked));
|
||||||
title_hb->add_child(create_plugin);
|
title_hb->add_child(create_plugin);
|
||||||
update_list = memnew(Button(TTR("Update")));
|
|
||||||
update_list->connect("pressed", callable_mp(this, &EditorPluginSettings::update_plugins));
|
|
||||||
title_hb->add_child(update_list);
|
|
||||||
add_child(title_hb);
|
add_child(title_hb);
|
||||||
|
|
||||||
plugin_list = memnew(Tree);
|
plugin_list = memnew(Tree);
|
||||||
|
@ -45,8 +45,6 @@ class EditorPluginSettings : public VBoxContainer {
|
|||||||
};
|
};
|
||||||
|
|
||||||
PluginConfigDialog *plugin_config_dialog = nullptr;
|
PluginConfigDialog *plugin_config_dialog = nullptr;
|
||||||
Button *create_plugin = nullptr;
|
|
||||||
Button *update_list = nullptr;
|
|
||||||
Tree *plugin_list = nullptr;
|
Tree *plugin_list = nullptr;
|
||||||
bool updating = false;
|
bool updating = false;
|
||||||
|
|
||||||
|
@ -47,7 +47,7 @@ void PluginConfigDialog::_clear_fields() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void PluginConfigDialog::_on_confirmed() {
|
void PluginConfigDialog::_on_confirmed() {
|
||||||
String path = "res://addons/" + subfolder_edit->get_text();
|
String path = "res://addons/" + _get_subfolder();
|
||||||
|
|
||||||
if (!_edit_mode) {
|
if (!_edit_mode) {
|
||||||
Ref<DirAccess> d = DirAccess::create(DirAccess::ACCESS_RESOURCES);
|
Ref<DirAccess> d = DirAccess::create(DirAccess::ACCESS_RESOURCES);
|
||||||
@ -56,32 +56,35 @@ void PluginConfigDialog::_on_confirmed() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int lang_idx = script_option_edit->get_selected();
|
||||||
|
String ext = ScriptServer::get_language(lang_idx)->get_extension();
|
||||||
|
String script_name = script_edit->get_text().is_empty() ? _get_subfolder() : script_edit->get_text();
|
||||||
|
if (script_name.get_extension().is_empty()) {
|
||||||
|
script_name += "." + ext;
|
||||||
|
}
|
||||||
|
String script_path = path.plus_file(script_name);
|
||||||
|
|
||||||
Ref<ConfigFile> cf = memnew(ConfigFile);
|
Ref<ConfigFile> cf = memnew(ConfigFile);
|
||||||
cf->set_value("plugin", "name", name_edit->get_text());
|
cf->set_value("plugin", "name", name_edit->get_text());
|
||||||
cf->set_value("plugin", "description", desc_edit->get_text());
|
cf->set_value("plugin", "description", desc_edit->get_text());
|
||||||
cf->set_value("plugin", "author", author_edit->get_text());
|
cf->set_value("plugin", "author", author_edit->get_text());
|
||||||
cf->set_value("plugin", "version", version_edit->get_text());
|
cf->set_value("plugin", "version", version_edit->get_text());
|
||||||
cf->set_value("plugin", "script", script_edit->get_text());
|
cf->set_value("plugin", "script", script_name);
|
||||||
|
|
||||||
cf->save(path.plus_file("plugin.cfg"));
|
cf->save(path.plus_file("plugin.cfg"));
|
||||||
|
|
||||||
if (!_edit_mode) {
|
if (!_edit_mode) {
|
||||||
int lang_idx = script_option_edit->get_selected();
|
String class_name = script_name.get_basename();
|
||||||
String lang_name = ScriptServer::get_language(lang_idx)->get_name();
|
|
||||||
|
|
||||||
Ref<Script> script;
|
|
||||||
String script_path = path.plus_file(script_edit->get_text());
|
|
||||||
String class_name = script_path.get_file().get_basename();
|
|
||||||
String template_content = "";
|
String template_content = "";
|
||||||
Vector<ScriptLanguage::ScriptTemplate> templates = ScriptServer::get_language(lang_idx)->get_built_in_templates("EditorPlugin");
|
Vector<ScriptLanguage::ScriptTemplate> templates = ScriptServer::get_language(lang_idx)->get_built_in_templates("EditorPlugin");
|
||||||
if (templates.size() > 0) {
|
if (!templates.is_empty()) {
|
||||||
template_content = templates.get(0).content;
|
template_content = templates[0].content;
|
||||||
}
|
}
|
||||||
script = ScriptServer::get_language(lang_idx)->make_template(template_content, class_name, "EditorPlugin");
|
Ref<Script> script = ScriptServer::get_language(lang_idx)->make_template(template_content, class_name, "EditorPlugin");
|
||||||
script->set_path(script_path);
|
script->set_path(script_path);
|
||||||
ResourceSaver::save(script_path, script);
|
ResourceSaver::save(script_path, script);
|
||||||
|
|
||||||
emit_signal(SNAME("plugin_ready"), script.operator->(), active_edit->is_pressed() ? _to_absolute_plugin_path(subfolder_edit->get_text()) : "");
|
emit_signal(SNAME("plugin_ready"), script.ptr(), active_edit->is_pressed() ? _to_absolute_plugin_path(_get_subfolder()) : "");
|
||||||
} else {
|
} else {
|
||||||
EditorNode::get_singleton()->get_project_settings()->update_plugins();
|
EditorNode::get_singleton()->get_project_settings()->update_plugins();
|
||||||
}
|
}
|
||||||
@ -119,27 +122,18 @@ void PluginConfigDialog::_on_required_text_changed(const String &) {
|
|||||||
name_validation->set_texture(invalid_icon);
|
name_validation->set_texture(invalid_icon);
|
||||||
name_validation->set_tooltip(TTR("Plugin name cannot be blank."));
|
name_validation->set_tooltip(TTR("Plugin name cannot be blank."));
|
||||||
}
|
}
|
||||||
if (script_edit->get_text().get_extension() != ext) {
|
if ((!script_edit->get_text().get_extension().is_empty() && script_edit->get_text().get_extension() != ext) || script_edit->get_text().ends_with(".")) {
|
||||||
is_valid = false;
|
is_valid = false;
|
||||||
script_validation->set_texture(invalid_icon);
|
script_validation->set_texture(invalid_icon);
|
||||||
script_validation->set_tooltip(vformat(TTR("Script extension must match chosen language extension (.%s)."), ext));
|
script_validation->set_tooltip(vformat(TTR("Script extension must match chosen language extension (.%s)."), ext));
|
||||||
}
|
}
|
||||||
if (script_edit->get_text().get_basename().is_empty()) {
|
if (!subfolder_edit->get_text().is_empty() && !subfolder_edit->get_text().is_valid_filename()) {
|
||||||
is_valid = false;
|
is_valid = false;
|
||||||
script_validation->set_texture(invalid_icon);
|
|
||||||
script_validation->set_tooltip(TTR("Script name cannot be blank."));
|
|
||||||
}
|
|
||||||
if (subfolder_edit->get_text().is_empty()) {
|
|
||||||
is_valid = false;
|
|
||||||
subfolder_validation->set_texture(invalid_icon);
|
|
||||||
subfolder_validation->set_tooltip(TTR("Subfolder cannot be blank."));
|
|
||||||
} else if (!subfolder_edit->get_text().is_valid_filename()) {
|
|
||||||
subfolder_validation->set_texture(invalid_icon);
|
subfolder_validation->set_texture(invalid_icon);
|
||||||
subfolder_validation->set_tooltip(TTR("Subfolder name is not a valid folder name."));
|
subfolder_validation->set_tooltip(TTR("Subfolder name is not a valid folder name."));
|
||||||
} else {
|
} else {
|
||||||
Ref<DirAccess> dir = DirAccess::create(DirAccess::ACCESS_RESOURCES);
|
String path = "res://addons/" + _get_subfolder();
|
||||||
String path = "res://addons/" + subfolder_edit->get_text();
|
if (!_edit_mode && DirAccess::exists(path)) { // Only show this error if in "create" mode.
|
||||||
if (dir->dir_exists(path) && !_edit_mode) { // Only show this error if in "create" mode.
|
|
||||||
is_valid = false;
|
is_valid = false;
|
||||||
subfolder_validation->set_texture(invalid_icon);
|
subfolder_validation->set_texture(invalid_icon);
|
||||||
subfolder_validation->set_tooltip(TTR("Subfolder cannot be one which already exists."));
|
subfolder_validation->set_tooltip(TTR("Subfolder cannot be one which already exists."));
|
||||||
@ -149,6 +143,10 @@ void PluginConfigDialog::_on_required_text_changed(const String &) {
|
|||||||
get_ok_button()->set_disabled(!is_valid);
|
get_ok_button()->set_disabled(!is_valid);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
String PluginConfigDialog::_get_subfolder() {
|
||||||
|
return subfolder_edit->get_text().is_empty() ? name_edit->get_text().replace(" ", "_").to_lower() : subfolder_edit->get_text();
|
||||||
|
}
|
||||||
|
|
||||||
String PluginConfigDialog::_to_absolute_plugin_path(const String &p_plugin_name) {
|
String PluginConfigDialog::_to_absolute_plugin_path(const String &p_plugin_name) {
|
||||||
return "res://addons/" + p_plugin_name + "/plugin.cfg";
|
return "res://addons/" + p_plugin_name + "/plugin.cfg";
|
||||||
}
|
}
|
||||||
@ -225,6 +223,7 @@ PluginConfigDialog::PluginConfigDialog() {
|
|||||||
// Plugin Name
|
// Plugin Name
|
||||||
Label *name_lb = memnew(Label);
|
Label *name_lb = memnew(Label);
|
||||||
name_lb->set_text(TTR("Plugin Name:"));
|
name_lb->set_text(TTR("Plugin Name:"));
|
||||||
|
name_lb->set_horizontal_alignment(HORIZONTAL_ALIGNMENT_RIGHT);
|
||||||
grid->add_child(name_lb);
|
grid->add_child(name_lb);
|
||||||
|
|
||||||
name_validation = memnew(TextureRect);
|
name_validation = memnew(TextureRect);
|
||||||
@ -239,6 +238,7 @@ PluginConfigDialog::PluginConfigDialog() {
|
|||||||
// Subfolder
|
// Subfolder
|
||||||
Label *subfolder_lb = memnew(Label);
|
Label *subfolder_lb = memnew(Label);
|
||||||
subfolder_lb->set_text(TTR("Subfolder:"));
|
subfolder_lb->set_text(TTR("Subfolder:"));
|
||||||
|
subfolder_lb->set_horizontal_alignment(HORIZONTAL_ALIGNMENT_RIGHT);
|
||||||
grid->add_child(subfolder_lb);
|
grid->add_child(subfolder_lb);
|
||||||
|
|
||||||
subfolder_validation = memnew(TextureRect);
|
subfolder_validation = memnew(TextureRect);
|
||||||
@ -253,6 +253,7 @@ PluginConfigDialog::PluginConfigDialog() {
|
|||||||
// Description
|
// Description
|
||||||
Label *desc_lb = memnew(Label);
|
Label *desc_lb = memnew(Label);
|
||||||
desc_lb->set_text(TTR("Description:"));
|
desc_lb->set_text(TTR("Description:"));
|
||||||
|
desc_lb->set_horizontal_alignment(HORIZONTAL_ALIGNMENT_RIGHT);
|
||||||
grid->add_child(desc_lb);
|
grid->add_child(desc_lb);
|
||||||
|
|
||||||
Control *desc_spacer = memnew(Control);
|
Control *desc_spacer = memnew(Control);
|
||||||
@ -266,6 +267,7 @@ PluginConfigDialog::PluginConfigDialog() {
|
|||||||
// Author
|
// Author
|
||||||
Label *author_lb = memnew(Label);
|
Label *author_lb = memnew(Label);
|
||||||
author_lb->set_text(TTR("Author:"));
|
author_lb->set_text(TTR("Author:"));
|
||||||
|
author_lb->set_horizontal_alignment(HORIZONTAL_ALIGNMENT_RIGHT);
|
||||||
grid->add_child(author_lb);
|
grid->add_child(author_lb);
|
||||||
|
|
||||||
Control *author_spacer = memnew(Control);
|
Control *author_spacer = memnew(Control);
|
||||||
@ -278,6 +280,7 @@ PluginConfigDialog::PluginConfigDialog() {
|
|||||||
// Version
|
// Version
|
||||||
Label *version_lb = memnew(Label);
|
Label *version_lb = memnew(Label);
|
||||||
version_lb->set_text(TTR("Version:"));
|
version_lb->set_text(TTR("Version:"));
|
||||||
|
version_lb->set_horizontal_alignment(HORIZONTAL_ALIGNMENT_RIGHT);
|
||||||
grid->add_child(version_lb);
|
grid->add_child(version_lb);
|
||||||
|
|
||||||
Control *version_spacer = memnew(Control);
|
Control *version_spacer = memnew(Control);
|
||||||
@ -290,6 +293,7 @@ PluginConfigDialog::PluginConfigDialog() {
|
|||||||
// Language dropdown
|
// Language dropdown
|
||||||
Label *script_option_lb = memnew(Label);
|
Label *script_option_lb = memnew(Label);
|
||||||
script_option_lb->set_text(TTR("Language:"));
|
script_option_lb->set_text(TTR("Language:"));
|
||||||
|
script_option_lb->set_horizontal_alignment(HORIZONTAL_ALIGNMENT_RIGHT);
|
||||||
grid->add_child(script_option_lb);
|
grid->add_child(script_option_lb);
|
||||||
|
|
||||||
Control *script_opt_spacer = memnew(Control);
|
Control *script_opt_spacer = memnew(Control);
|
||||||
@ -311,6 +315,7 @@ PluginConfigDialog::PluginConfigDialog() {
|
|||||||
// Plugin Script Name
|
// Plugin Script Name
|
||||||
Label *script_lb = memnew(Label);
|
Label *script_lb = memnew(Label);
|
||||||
script_lb->set_text(TTR("Script Name:"));
|
script_lb->set_text(TTR("Script Name:"));
|
||||||
|
script_lb->set_horizontal_alignment(HORIZONTAL_ALIGNMENT_RIGHT);
|
||||||
grid->add_child(script_lb);
|
grid->add_child(script_lb);
|
||||||
|
|
||||||
script_validation = memnew(TextureRect);
|
script_validation = memnew(TextureRect);
|
||||||
@ -326,6 +331,7 @@ PluginConfigDialog::PluginConfigDialog() {
|
|||||||
// TODO Make this option work better with languages like C#. Right now, it does not work because the C# project must be compiled first.
|
// TODO Make this option work better with languages like C#. Right now, it does not work because the C# project must be compiled first.
|
||||||
Label *active_lb = memnew(Label);
|
Label *active_lb = memnew(Label);
|
||||||
active_lb->set_text(TTR("Activate now?"));
|
active_lb->set_text(TTR("Activate now?"));
|
||||||
|
active_lb->set_horizontal_alignment(HORIZONTAL_ALIGNMENT_RIGHT);
|
||||||
grid->add_child(active_lb);
|
grid->add_child(active_lb);
|
||||||
|
|
||||||
Control *active_spacer = memnew(Control);
|
Control *active_spacer = memnew(Control);
|
||||||
|
@ -61,6 +61,7 @@ class PluginConfigDialog : public ConfirmationDialog {
|
|||||||
void _on_cancelled();
|
void _on_cancelled();
|
||||||
void _on_language_changed(const int p_language);
|
void _on_language_changed(const int p_language);
|
||||||
void _on_required_text_changed(const String &p_text);
|
void _on_required_text_changed(const String &p_text);
|
||||||
|
String _get_subfolder();
|
||||||
|
|
||||||
static String _to_absolute_plugin_path(const String &p_plugin_name);
|
static String _to_absolute_plugin_path(const String &p_plugin_name);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user