diff --git a/desktop/desktop.cpp b/desktop/desktop.cpp index d6099e4..7089c88 100644 --- a/desktop/desktop.cpp +++ b/desktop/desktop.cpp @@ -568,7 +568,7 @@ int ProcessGlobalKeyboardShortcuts(EsElement *, EsMessage *message) { bool ctrlOnly = message->keyboard.modifiers == ES_MODIFIER_CTRL; int scancode = message->keyboard.scancode; - if (ctrlOnly && scancode == ES_SCANCODE_N) { + if (ctrlOnly && scancode == ES_SCANCODE_N && !message->keyboard.repeat) { ApplicationInstanceCreate(APPLICATION_ID_DESKTOP_BLANK_TAB, nullptr, nullptr); } else if (message->keyboard.modifiers == (ES_MODIFIER_CTRL | ES_MODIFIER_FLAG) && scancode == ES_SCANCODE_D) { if (!desktop.inspectorOpen) { @@ -612,9 +612,9 @@ int ContainerWindowMessage(EsElement *element, EsMessage *message) { if (tab == -1) tab = container->tabBand->items.Length() - 1; if (tab == (int) container->tabBand->items.Length()) tab = 0; WindowTabActivate((WindowTab *) container->tabBand->items[tab]); - } else if (ctrlOnly && scancode == ES_SCANCODE_T) { + } else if (ctrlOnly && scancode == ES_SCANCODE_T && !message->keyboard.repeat) { ApplicationInstanceCreate(APPLICATION_ID_DESKTOP_BLANK_TAB, nullptr, container); - } else if (ctrlOnly && scancode == ES_SCANCODE_W) { + } else if (ctrlOnly && scancode == ES_SCANCODE_W && !message->keyboard.repeat) { WindowTabClose(container->active); } else if (message->keyboard.modifiers == ES_MODIFIER_FLAG && scancode == ES_SCANCODE_UP_ARROW) { WindowSnap(container->window, false, false, SNAP_EDGE_MAXIMIZE); @@ -851,6 +851,35 @@ int WindowTabBandMessage(EsElement *element, EsMessage *message) { } else if (message->type == ES_MSG_MOUSE_RIGHT_CLICK) { EsMenu *menu = EsMenuCreate(band, ES_MENU_AT_CURSOR); + EsMenuAddItem(menu, ES_FLAGS_DEFAULT, + band->items.Length() > 1 ? interfaceString_DesktopCloseAllTabs : interfaceString_DesktopCloseWindow, -1, + [] (EsMenu *, EsGeneric context) { + WindowTabBand *band = (WindowTabBand *) context.p; + + for (uintptr_t i = 0; i < band->items.Length(); i++) { + WindowTabClose((WindowTab *) band->items[i]); + } + }, band); + + EsMenuAddSeparator(menu); + + EsMenuAddItem(menu, band->window->isMaximised ? ES_ELEMENT_DISABLED : ES_FLAGS_DEFAULT, + INTERFACE_STRING(DesktopMaximiseWindow), [] (EsMenu *, EsGeneric context) { + WindowSnap((EsWindow *) context.p, false, false, SNAP_EDGE_MAXIMIZE); + }, band->window); + + EsMenuAddItem(menu, band->window->isMaximised ? ES_ELEMENT_DISABLED : ES_FLAGS_DEFAULT, + INTERFACE_STRING(DesktopMinimiseWindow), [] (EsMenu *, EsGeneric context) { + EsSyscall(ES_SYSCALL_WINDOW_MOVE, ((EsWindow *) context.p)->handle, 0, 0, ES_WINDOW_MOVE_HIDDEN); + }, band->window); + + EsMenuAddItem(menu, !band->window->isMaximised ? ES_ELEMENT_DISABLED : ES_FLAGS_DEFAULT, + INTERFACE_STRING(DesktopRestoreWindow), [] (EsMenu *, EsGeneric context) { + WindowRestore((EsWindow *) context.p); + }, band->window); + + EsMenuAddSeparator(menu); + EsMenuAddItem(menu, band->window->isMaximised ? ES_ELEMENT_DISABLED : ES_FLAGS_DEFAULT, INTERFACE_STRING(DesktopCenterWindow), [] (EsMenu *, EsGeneric context) { WindowTabBand *band = (WindowTabBand *) context.p; @@ -861,15 +890,15 @@ int WindowTabBandMessage(EsElement *element, EsMessage *message) { EsSyscall(ES_SYSCALL_WINDOW_MOVE, band->window->handle, (uintptr_t) &newBounds, 0, ES_FLAGS_DEFAULT); }, band); - EsMenuAddItem(menu, band->window->isMaximised ? ES_ELEMENT_DISABLED : ES_FLAGS_DEFAULT, - band->items.Length() > 1 ? interfaceString_DesktopCloseAllTabs : interfaceString_DesktopCloseWindow, -1, - [] (EsMenu *, EsGeneric context) { - WindowTabBand *band = (WindowTabBand *) context.p; + EsMenuAddItem(menu, ES_FLAGS_DEFAULT, + INTERFACE_STRING(DesktopSnapWindowLeft), [] (EsMenu *, EsGeneric context) { + WindowSnap((EsWindow *) context.p, false, false, SNAP_EDGE_LEFT); + }, band->window); - for (uintptr_t i = 0; i < band->items.Length(); i++) { - WindowTabClose((WindowTab *) band->items[i]); - } - }, band); + EsMenuAddItem(menu, ES_FLAGS_DEFAULT, + INTERFACE_STRING(DesktopSnapWindowRight), [] (EsMenu *, EsGeneric context) { + WindowSnap((EsWindow *) context.p, false, false, SNAP_EDGE_RIGHT); + }, band->window); EsMenuShow(menu); } else { @@ -1139,7 +1168,7 @@ void ShutdownModalCreate() { EsSyscall(ES_SYSCALL_WINDOW_SET_PROPERTY, window->handle, (uintptr_t) &screen, 0, ES_WINDOW_PROPERTY_BLUR_BOUNDS); EsSyscall(ES_SYSCALL_WINDOW_SET_PROPERTY, window->handle, ES_WINDOW_SOLID_TRUE, 0, ES_WINDOW_PROPERTY_SOLID); EsSyscall(ES_SYSCALL_WINDOW_SET_PROPERTY, window->handle, 0, 0, ES_WINDOW_PROPERTY_FOCUSED); - EsSyscall(ES_SYSCALL_WINDOW_SET_PROPERTY, window->handle, BLEND_WINDOW_MATERIAL_LIGHT_BLUR, 0, ES_WINDOW_PROPERTY_MATERIAL); + // EsSyscall(ES_SYSCALL_WINDOW_SET_PROPERTY, window->handle, BLEND_WINDOW_MATERIAL_LIGHT_BLUR, 0, ES_WINDOW_PROPERTY_MATERIAL); // Setup the UI. diff --git a/desktop/gui.cpp b/desktop/gui.cpp index ea89e3b..162de9a 100644 --- a/desktop/gui.cpp +++ b/desktop/gui.cpp @@ -5272,7 +5272,7 @@ void FileMenuCreate(EsInstance *_instance, EsElement *element, EsCommand *) { instance->startupInformation->filePath, instance->startupInformation->filePathBytes); } - EsButton *renameButton = EsButtonCreate(panel3, ES_BUTTON_TOOLBAR); // TODO. + EsButton *renameButton = EsButtonCreate(panel3, ES_BUTTON_TOOLBAR); if (!renameButton) goto show; EsButtonSetIcon(renameButton, ES_ICON_DOCUMENT_EDIT_SYMBOLIC); EsButtonOnCommand(renameButton, FileMenuRename); @@ -5293,22 +5293,22 @@ void FileMenuCreate(EsInstance *_instance, EsElement *element, EsCommand *) { } } - EsMenuAddSeparator(menu); + if (instance->instanceClass == ES_INSTANCE_CLASS_EDITOR && !newDocument) { + EsMenuAddSeparator(menu); - if (instance->instanceClass == ES_INSTANCE_CLASS_EDITOR) { if (instance->commandSave.disabled) { EsMenuAddItem(menu, ES_ELEMENT_DISABLED, INTERFACE_STRING(CommonFileUnchanged)); } else { EsMenuAddCommand(menu, ES_FLAGS_DEFAULT, INTERFACE_STRING(CommonFileSave), &instance->commandSave); } - EsMenuAddItem(menu, newDocument ? ES_ELEMENT_DISABLED : ES_FLAGS_DEFAULT, INTERFACE_STRING(CommonFileMakeCopy)); // TODO. + // EsMenuAddItem(menu, newDocument ? ES_ELEMENT_DISABLED : ES_FLAGS_DEFAULT, INTERFACE_STRING(CommonFileMakeCopy)); // TODO. EsMenuAddSeparator(menu); - } - EsMenuAddItem(menu, newDocument ? ES_ELEMENT_DISABLED : ES_FLAGS_DEFAULT, INTERFACE_STRING(CommonFileShare)); // TODO. - EsMenuAddItem(menu, newDocument ? ES_ELEMENT_DISABLED : ES_FLAGS_DEFAULT, INTERFACE_STRING(CommonFileVersionHistory)); // TODO. - EsMenuAddCommand(menu, ES_FLAGS_DEFAULT, INTERFACE_STRING(CommonFileShowInFileManager), &instance->commandShowInFileManager); + // EsMenuAddItem(menu, newDocument ? ES_ELEMENT_DISABLED : ES_FLAGS_DEFAULT, INTERFACE_STRING(CommonFileShare)); // TODO. + // EsMenuAddItem(menu, newDocument ? ES_ELEMENT_DISABLED : ES_FLAGS_DEFAULT, INTERFACE_STRING(CommonFileVersionHistory)); // TODO. + EsMenuAddCommand(menu, ES_FLAGS_DEFAULT, INTERFACE_STRING(CommonFileShowInFileManager), &instance->commandShowInFileManager); + } show: EsMenuShow(menu); } diff --git a/shared/strings.cpp b/shared/strings.cpp index f574440..a1931ab 100644 --- a/shared/strings.cpp +++ b/shared/strings.cpp @@ -92,9 +92,14 @@ DEFINE_INTERFACE_STRING(DesktopConfirmShutdown, "Are you sure you want to turn o DEFINE_INTERFACE_STRING(DesktopCloseTab, "Close tab"); DEFINE_INTERFACE_STRING(DesktopMoveTabToNewWindow, "Move to new window"); DEFINE_INTERFACE_STRING(DesktopInspectUI, "Inspect UI"); -DEFINE_INTERFACE_STRING(DesktopCenterWindow, "Center in screen"); DEFINE_INTERFACE_STRING(DesktopCloseWindow, "Close window"); DEFINE_INTERFACE_STRING(DesktopCloseAllTabs, "Close all tabs"); +DEFINE_INTERFACE_STRING(DesktopMaximiseWindow, "Fill screen"); +DEFINE_INTERFACE_STRING(DesktopRestoreWindow, "Restore position"); +DEFINE_INTERFACE_STRING(DesktopMinimiseWindow, "Hide"); +DEFINE_INTERFACE_STRING(DesktopCenterWindow, "Center in screen"); +DEFINE_INTERFACE_STRING(DesktopSnapWindowLeft, "Move to left side"); +DEFINE_INTERFACE_STRING(DesktopSnapWindowRight, "Move to right side"); DEFINE_INTERFACE_STRING(DesktopSettingsApplication, "Settings"); DEFINE_INTERFACE_STRING(DesktopSettingsTitle, "Settings");