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) {
|
||||
|
||||
if (editable == p_editable)
|
||||
return;
|
||||
|
||||
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();
|
||||
}
|
||||
|
||||
@ -1624,7 +1644,6 @@ LineEdit::LineEdit() {
|
||||
|
||||
deselect();
|
||||
set_focus_mode(FOCUS_ALL);
|
||||
editable = true;
|
||||
set_default_cursor_shape(CURSOR_IBEAM);
|
||||
set_mouse_filter(MOUSE_FILTER_STOP);
|
||||
|
||||
@ -1639,15 +1658,7 @@ LineEdit::LineEdit() {
|
||||
context_menu_enabled = true;
|
||||
menu = memnew(PopupMenu);
|
||||
add_child(menu);
|
||||
menu->add_item(RTR("Cut"), MENU_CUT, KEY_MASK_CMD | KEY_X);
|
||||
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);
|
||||
set_editable(true);
|
||||
menu->connect("id_pressed", this, "menu_option");
|
||||
expand_to_text_length = false;
|
||||
}
|
||||
|
@ -4363,7 +4363,27 @@ void TextEdit::clear() {
|
||||
|
||||
void TextEdit::set_readonly(bool p_readonly) {
|
||||
|
||||
if (readonly == p_readonly)
|
||||
return;
|
||||
|
||||
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();
|
||||
}
|
||||
|
||||
@ -6387,7 +6407,6 @@ void TextEdit::_bind_methods() {
|
||||
|
||||
TextEdit::TextEdit() {
|
||||
|
||||
readonly = false;
|
||||
setting_row = false;
|
||||
draw_tabs = false;
|
||||
override_selected_font_color = false;
|
||||
@ -6502,15 +6521,7 @@ TextEdit::TextEdit() {
|
||||
context_menu_enabled = true;
|
||||
menu = memnew(PopupMenu);
|
||||
add_child(menu);
|
||||
menu->add_item(RTR("Cut"), MENU_CUT, KEY_MASK_CMD | KEY_X);
|
||||
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);
|
||||
set_readonly(false);
|
||||
menu->connect("id_pressed", this, "menu_option");
|
||||
first_draw = true;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user