mirror of
https://github.com/RGBCube/serenity
synced 2025-05-31 13:38:11 +00:00
FileManager: Add separate context menus for entries
Ref: #826 Right-clicking a directory no longer has the "Open in TextEditor" entry. Right-clicking the directory view now allows you to create a new directory.
This commit is contained in:
parent
5e6368948e
commit
875ab0cf10
1 changed files with 30 additions and 10 deletions
|
@ -412,17 +412,37 @@ int main(int argc, char** argv)
|
|||
}
|
||||
});
|
||||
|
||||
auto context_menu = make<GMenu>();
|
||||
context_menu->add_action(copy_action);
|
||||
context_menu->add_action(paste_action);
|
||||
context_menu->add_action(delete_action);
|
||||
context_menu->add_separator();
|
||||
context_menu->add_action(open_in_text_editor_action);
|
||||
context_menu->add_separator();
|
||||
context_menu->add_action(properties_action);
|
||||
auto directory_context_menu = make<GMenu>();
|
||||
directory_context_menu->add_action(copy_action);
|
||||
directory_context_menu->add_action(paste_action);
|
||||
directory_context_menu->add_action(delete_action);
|
||||
directory_context_menu->add_separator();
|
||||
directory_context_menu->add_action(properties_action);
|
||||
|
||||
directory_view->on_context_menu_request = [&](const GAbstractView&, const GModelIndex&, const GContextMenuEvent& event) {
|
||||
context_menu->popup(event.screen_position());
|
||||
auto file_context_menu = make<GMenu>();
|
||||
file_context_menu->add_action(copy_action);
|
||||
file_context_menu->add_action(paste_action);
|
||||
file_context_menu->add_action(delete_action);
|
||||
file_context_menu->add_separator();
|
||||
file_context_menu->add_action(open_in_text_editor_action);
|
||||
file_context_menu->add_separator();
|
||||
file_context_menu->add_action(properties_action);
|
||||
|
||||
auto directory_view_context_menu = make<GMenu>();
|
||||
directory_view_context_menu->add_action(mkdir_action);
|
||||
|
||||
directory_view->on_context_menu_request = [&](const GAbstractView&, const GModelIndex& index, const GContextMenuEvent& event) {
|
||||
if (index.is_valid()) {
|
||||
auto& entry = directory_view->model().entry(index.row());
|
||||
|
||||
if (entry.is_directory()) {
|
||||
directory_context_menu->popup(event.screen_position());
|
||||
} else {
|
||||
file_context_menu->popup(event.screen_position());
|
||||
}
|
||||
} else {
|
||||
directory_view_context_menu->popup(event.screen_position());
|
||||
}
|
||||
};
|
||||
|
||||
// our initial location is defined as, in order of precedence:
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue