Merge pull request #28287 from YeldhamDev/text_editable_contextmenu
Make 'Line/TextEdit's context menus hide their editing options when in readonly mode
This commit is contained in:
commit
ea30bcdfef
@ -1328,7 +1328,27 @@ void LineEdit::select_all() {
|
|||||||
|
|
||||||
void LineEdit::set_editable(bool p_editable) {
|
void LineEdit::set_editable(bool p_editable) {
|
||||||
|
|
||||||
|
if (editable == p_editable)
|
||||||
|
return;
|
||||||
|
|
||||||
editable = p_editable;
|
editable = p_editable;
|
||||||
|
|
||||||
|
// Reorganize context menu.
|
||||||
|
menu->clear();
|
||||||
|
if (editable)
|
||||||
|
menu->add_item(RTR("Cut"), MENU_CUT, KEY_MASK_CMD | KEY_X);
|
||||||
|
menu->add_item(RTR("Copy"), MENU_COPY, KEY_MASK_CMD | KEY_C);
|
||||||
|
if (editable)
|
||||||
|
menu->add_item(RTR("Paste"), MENU_PASTE, KEY_MASK_CMD | KEY_V);
|
||||||
|
menu->add_separator();
|
||||||
|
menu->add_item(RTR("Select All"), MENU_SELECT_ALL, KEY_MASK_CMD | KEY_A);
|
||||||
|
if (editable) {
|
||||||
|
menu->add_item(RTR("Clear"), MENU_CLEAR);
|
||||||
|
menu->add_separator();
|
||||||
|
menu->add_item(RTR("Undo"), MENU_UNDO, KEY_MASK_CMD | KEY_Z);
|
||||||
|
menu->add_item(RTR("Redo"), MENU_REDO, KEY_MASK_CMD | KEY_MASK_SHIFT | KEY_Z);
|
||||||
|
}
|
||||||
|
|
||||||
update();
|
update();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1624,7 +1644,6 @@ LineEdit::LineEdit() {
|
|||||||
|
|
||||||
deselect();
|
deselect();
|
||||||
set_focus_mode(FOCUS_ALL);
|
set_focus_mode(FOCUS_ALL);
|
||||||
editable = true;
|
|
||||||
set_default_cursor_shape(CURSOR_IBEAM);
|
set_default_cursor_shape(CURSOR_IBEAM);
|
||||||
set_mouse_filter(MOUSE_FILTER_STOP);
|
set_mouse_filter(MOUSE_FILTER_STOP);
|
||||||
|
|
||||||
@ -1639,15 +1658,7 @@ LineEdit::LineEdit() {
|
|||||||
context_menu_enabled = true;
|
context_menu_enabled = true;
|
||||||
menu = memnew(PopupMenu);
|
menu = memnew(PopupMenu);
|
||||||
add_child(menu);
|
add_child(menu);
|
||||||
menu->add_item(RTR("Cut"), MENU_CUT, KEY_MASK_CMD | KEY_X);
|
set_editable(true);
|
||||||
menu->add_item(RTR("Copy"), MENU_COPY, KEY_MASK_CMD | KEY_C);
|
|
||||||
menu->add_item(RTR("Paste"), MENU_PASTE, KEY_MASK_CMD | KEY_V);
|
|
||||||
menu->add_separator();
|
|
||||||
menu->add_item(RTR("Select All"), MENU_SELECT_ALL, KEY_MASK_CMD | KEY_A);
|
|
||||||
menu->add_item(RTR("Clear"), MENU_CLEAR);
|
|
||||||
menu->add_separator();
|
|
||||||
menu->add_item(RTR("Undo"), MENU_UNDO, KEY_MASK_CMD | KEY_Z);
|
|
||||||
menu->add_item(RTR("Redo"), MENU_REDO, KEY_MASK_CMD | KEY_MASK_SHIFT | KEY_Z);
|
|
||||||
menu->connect("id_pressed", this, "menu_option");
|
menu->connect("id_pressed", this, "menu_option");
|
||||||
expand_to_text_length = false;
|
expand_to_text_length = false;
|
||||||
}
|
}
|
||||||
|
@ -4363,7 +4363,27 @@ void TextEdit::clear() {
|
|||||||
|
|
||||||
void TextEdit::set_readonly(bool p_readonly) {
|
void TextEdit::set_readonly(bool p_readonly) {
|
||||||
|
|
||||||
|
if (readonly == p_readonly)
|
||||||
|
return;
|
||||||
|
|
||||||
readonly = p_readonly;
|
readonly = p_readonly;
|
||||||
|
|
||||||
|
// Reorganize context menu.
|
||||||
|
menu->clear();
|
||||||
|
if (!readonly)
|
||||||
|
menu->add_item(RTR("Cut"), MENU_CUT, KEY_MASK_CMD | KEY_X);
|
||||||
|
menu->add_item(RTR("Copy"), MENU_COPY, KEY_MASK_CMD | KEY_C);
|
||||||
|
if (!readonly)
|
||||||
|
menu->add_item(RTR("Paste"), MENU_PASTE, KEY_MASK_CMD | KEY_V);
|
||||||
|
menu->add_separator();
|
||||||
|
menu->add_item(RTR("Select All"), MENU_SELECT_ALL, KEY_MASK_CMD | KEY_A);
|
||||||
|
if (!readonly) {
|
||||||
|
menu->add_item(RTR("Clear"), MENU_CLEAR);
|
||||||
|
menu->add_separator();
|
||||||
|
menu->add_item(RTR("Undo"), MENU_UNDO, KEY_MASK_CMD | KEY_Z);
|
||||||
|
menu->add_item(RTR("Redo"), MENU_REDO, KEY_MASK_CMD | KEY_MASK_SHIFT | KEY_Z);
|
||||||
|
}
|
||||||
|
|
||||||
update();
|
update();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -6387,7 +6407,6 @@ void TextEdit::_bind_methods() {
|
|||||||
|
|
||||||
TextEdit::TextEdit() {
|
TextEdit::TextEdit() {
|
||||||
|
|
||||||
readonly = false;
|
|
||||||
setting_row = false;
|
setting_row = false;
|
||||||
draw_tabs = false;
|
draw_tabs = false;
|
||||||
override_selected_font_color = false;
|
override_selected_font_color = false;
|
||||||
@ -6502,15 +6521,7 @@ TextEdit::TextEdit() {
|
|||||||
context_menu_enabled = true;
|
context_menu_enabled = true;
|
||||||
menu = memnew(PopupMenu);
|
menu = memnew(PopupMenu);
|
||||||
add_child(menu);
|
add_child(menu);
|
||||||
menu->add_item(RTR("Cut"), MENU_CUT, KEY_MASK_CMD | KEY_X);
|
set_readonly(false);
|
||||||
menu->add_item(RTR("Copy"), MENU_COPY, KEY_MASK_CMD | KEY_C);
|
|
||||||
menu->add_item(RTR("Paste"), MENU_PASTE, KEY_MASK_CMD | KEY_V);
|
|
||||||
menu->add_separator();
|
|
||||||
menu->add_item(RTR("Select All"), MENU_SELECT_ALL, KEY_MASK_CMD | KEY_A);
|
|
||||||
menu->add_item(RTR("Clear"), MENU_CLEAR);
|
|
||||||
menu->add_separator();
|
|
||||||
menu->add_item(RTR("Undo"), MENU_UNDO, KEY_MASK_CMD | KEY_Z);
|
|
||||||
menu->add_item(RTR("Redo"), MENU_REDO, KEY_MASK_CMD | KEY_MASK_SHIFT | KEY_Z);
|
|
||||||
menu->connect("id_pressed", this, "menu_option");
|
menu->connect("id_pressed", this, "menu_option");
|
||||||
first_draw = true;
|
first_draw = true;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user