Regression fixup to the theme editor

This commit is contained in:
Michael Alexsander Silva Dias 2019-08-13 15:09:25 -03:00
parent 7863ea39db
commit b7c2bcff76
2 changed files with 37 additions and 36 deletions

View File

@ -36,6 +36,7 @@
void ThemeEditor::edit(const Ref<Theme> &p_theme) { void ThemeEditor::edit(const Ref<Theme> &p_theme) {
theme = p_theme; theme = p_theme;
main_panel->set_theme(p_theme);
main_container->set_theme(p_theme); main_container->set_theme(p_theme);
} }
@ -53,6 +54,7 @@ void ThemeEditor::_propagate_redraw(Control *p_at) {
void ThemeEditor::_refresh_interval() { void ThemeEditor::_refresh_interval() {
_propagate_redraw(main_panel);
_propagate_redraw(main_container); _propagate_redraw(main_container);
} }
@ -130,14 +132,14 @@ void ThemeEditor::_save_template_cbk(String fname) {
Map<String, _TECategory> categories; Map<String, _TECategory> categories;
//fill types // Fill types.
List<StringName> type_list; List<StringName> type_list;
Theme::get_default()->get_type_list(&type_list); Theme::get_default()->get_type_list(&type_list);
for (List<StringName>::Element *E = type_list.front(); E; E = E->next()) { for (List<StringName>::Element *E = type_list.front(); E; E = E->next()) {
categories.insert(E->get(), _TECategory()); categories.insert(E->get(), _TECategory());
} }
//fill default theme // Fill default theme.
for (Map<String, _TECategory>::Element *E = categories.front(); E; E = E->next()) { for (Map<String, _TECategory>::Element *E = categories.front(); E; E = E->next()) {
_TECategory &tc = E->get(); _TECategory &tc = E->get();
@ -256,7 +258,7 @@ void ThemeEditor::_save_template_cbk(String fname) {
file->store_line(""); file->store_line("");
file->store_line(""); file->store_line("");
//write default theme // Write default theme.
for (Map<String, _TECategory>::Element *E = categories.front(); E; E = E->next()) { for (Map<String, _TECategory>::Element *E = categories.front(); E; E = E->next()) {
_TECategory &tc = E->get(); _TECategory &tc = E->get();
@ -501,7 +503,7 @@ void ThemeEditor::_theme_menu_cbk(int p_option) {
type_select_label->show(); type_select_label->show();
type_select->show(); type_select->show();
if (p_option == POPUP_ADD) { //add if (p_option == POPUP_ADD) { // Add.
add_del_dialog->set_title(TTR("Add Item")); add_del_dialog->set_title(TTR("Add Item"));
add_del_dialog->get_ok()->set_text(TTR("Add")); add_del_dialog->get_ok()->set_text(TTR("Add"));
@ -509,7 +511,7 @@ void ThemeEditor::_theme_menu_cbk(int p_option) {
base_theme = Theme::get_default(); base_theme = Theme::get_default();
} else if (p_option == POPUP_CLASS_ADD) { //add } else if (p_option == POPUP_CLASS_ADD) { // Add.
add_del_dialog->set_title(TTR("Add All Items")); add_del_dialog->set_title(TTR("Add All Items"));
add_del_dialog->get_ok()->set_text(TTR("Add All")); add_del_dialog->get_ok()->set_text(TTR("Add All"));
@ -552,12 +554,10 @@ void ThemeEditor::_theme_menu_cbk(int p_option) {
type_menu->get_popup()->clear(); type_menu->get_popup()->clear();
if (p_option == 0 || p_option == 1) { //add if (p_option == 0 || p_option == 1) { // Add.
List<StringName> new_types; List<StringName> new_types;
theme->get_type_list(&new_types); theme->get_type_list(&new_types);
//uh kind of sucks
for (List<StringName>::Element *F = new_types.front(); F; F = F->next()) { for (List<StringName>::Element *F = new_types.front(); F; F = F->next()) {
bool found = false; bool found = false;
@ -583,15 +583,17 @@ void ThemeEditor::_theme_menu_cbk(int p_option) {
void ThemeEditor::_notification(int p_what) { void ThemeEditor::_notification(int p_what) {
if (p_what == NOTIFICATION_PROCESS) { switch (p_what) {
case NOTIFICATION_PROCESS: {
time_left -= get_process_delta_time(); time_left -= get_process_delta_time();
if (time_left < 0) { if (time_left < 0) {
time_left = 1.5; time_left = 1.5;
_refresh_interval(); _refresh_interval();
} }
} else if (p_what == NOTIFICATION_THEME_CHANGED) { } break;
case NOTIFICATION_THEME_CHANGED: {
theme_menu->set_icon(get_icon("Theme", "EditorIcons")); theme_menu->set_icon(get_icon("Theme", "EditorIcons"));
} break;
} }
} }
@ -629,35 +631,34 @@ ThemeEditor::ThemeEditor() {
top_menu->add_child(theme_menu); top_menu->add_child(theme_menu);
theme_menu->get_popup()->connect("id_pressed", this, "_theme_menu_cbk"); theme_menu->get_popup()->connect("id_pressed", this, "_theme_menu_cbk");
scroll = memnew(ScrollContainer); ScrollContainer *scroll = memnew(ScrollContainer);
add_child(scroll); add_child(scroll);
scroll->set_enable_v_scroll(true); scroll->set_enable_v_scroll(true);
scroll->set_enable_h_scroll(false); scroll->set_enable_h_scroll(false);
scroll->set_v_size_flags(SIZE_EXPAND_FILL); scroll->set_v_size_flags(SIZE_EXPAND_FILL);
main_container = memnew(MarginContainer); MarginContainer *root_container = memnew(MarginContainer);
scroll->add_child(main_container); scroll->add_child(root_container);
main_container->set_clip_contents(true); root_container->set_theme(Theme::get_default());
main_container->set_custom_minimum_size(Size2(700, 0) * EDSCALE); root_container->set_clip_contents(true);
main_container->set_v_size_flags(SIZE_EXPAND_FILL); root_container->set_custom_minimum_size(Size2(700, 0) * EDSCALE);
main_container->set_h_size_flags(SIZE_EXPAND_FILL); root_container->set_v_size_flags(SIZE_EXPAND_FILL);
root_container->set_h_size_flags(SIZE_EXPAND_FILL);
//// Preview Controls //// //// Preview Controls ////
Panel *panel = memnew(Panel); main_panel = memnew(Panel);
main_container->add_child(panel); root_container->add_child(main_panel);
panel->set_theme(Theme::get_default());
MarginContainer *mc = memnew(MarginContainer); main_container = memnew(MarginContainer);
main_container->add_child(mc); root_container->add_child(main_container);
mc->set_theme(Theme::get_default()); main_container->add_constant_override("margin_right", 4 * EDSCALE);
mc->add_constant_override("margin_right", 4 * EDSCALE); main_container->add_constant_override("margin_top", 4 * EDSCALE);
mc->add_constant_override("margin_top", 4 * EDSCALE); main_container->add_constant_override("margin_left", 4 * EDSCALE);
mc->add_constant_override("margin_left", 4 * EDSCALE); main_container->add_constant_override("margin_bottom", 4 * EDSCALE);
mc->add_constant_override("margin_bottom", 4 * EDSCALE);
HBoxContainer *main_hb = memnew(HBoxContainer); HBoxContainer *main_hb = memnew(HBoxContainer);
mc->add_child(main_hb); main_container->add_child(main_hb);
VBoxContainer *first_vb = memnew(VBoxContainer); VBoxContainer *first_vb = memnew(VBoxContainer);
main_hb->add_child(first_vb); main_hb->add_child(first_vb);

View File

@ -45,7 +45,7 @@ class ThemeEditor : public VBoxContainer {
GDCLASS(ThemeEditor, VBoxContainer); GDCLASS(ThemeEditor, VBoxContainer);
ScrollContainer *scroll; Panel *main_panel;
MarginContainer *main_container; MarginContainer *main_container;
Ref<Theme> theme; Ref<Theme> theme;