diff --git a/PowerEditor/src/WinControls/ProjectPanel/ProjectPanel.cpp b/PowerEditor/src/WinControls/ProjectPanel/ProjectPanel.cpp index 63387b5b5..7069ee0d0 100644 --- a/PowerEditor/src/WinControls/ProjectPanel/ProjectPanel.cpp +++ b/PowerEditor/src/WinControls/ProjectPanel/ProjectPanel.cpp @@ -25,6 +25,7 @@ // along with this program; if not, write to the Free Software // Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. +#include #include "ProjectPanel.h" #include "resource.h" @@ -44,9 +45,6 @@ #define INDEX_LEAF 5 #define INDEX_LEAF_INVALID 6 -#define GET_X_LPARAM(lp) LOWORD(lp) -#define GET_Y_LPARAM(lp) HIWORD(lp) - INT_PTR CALLBACK ProjectPanel::run_dlgProc(UINT message, WPARAM wParam, LPARAM lParam) { switch (message) @@ -133,7 +131,30 @@ INT_PTR CALLBACK ProjectPanel::run_dlgProc(UINT message, WPARAM wParam, LPARAM l case WM_CONTEXTMENU: if (!_treeView.isDragging()) - showContextMenu(GET_X_LPARAM(lParam), GET_Y_LPARAM(lParam)); + { + int xPos = GET_X_LPARAM(lParam); + int yPos = GET_Y_LPARAM(lParam); + + // If the context menu is generated from the keyboard, then we + // should display it at the location of the current selection + if (xPos == -1 && yPos == -1) + { + HTREEITEM selectedItem = _treeView.getSelection(); + + if (selectedItem) + { + RECT selectedItemRect; + if (TreeView_GetItemRect(_treeView.getHSelf(), selectedItem, &selectedItemRect, TRUE)) + { + showContextMenuFromMenuKey(selectedItem, (selectedItemRect.left + selectedItemRect.right) / 2, (selectedItemRect.top + selectedItemRect.bottom) / 2); + } + } + } + else + { + showContextMenu(xPos, yPos); + } + } return TRUE; case WM_COMMAND: @@ -763,22 +784,44 @@ void ProjectPanel::showContextMenu(int x, int y) { // Make item selected _treeView.selectItem(tvHitInfo.hItem); - - // get clicked item type - NodeType nodeType = getNodeType(tvHitInfo.hItem); - HMENU hMenu = NULL; - if (nodeType == nodeType_root) - hMenu = _hWorkSpaceMenu; - else if (nodeType == nodeType_project) - hMenu = _hProjectMenu; - else if (nodeType == nodeType_folder) - hMenu = _hFolderMenu; - else //nodeType_file - hMenu = _hFileMenu; + HMENU hMenu = getMenuHandler(tvHitInfo.hItem); TrackPopupMenu(hMenu, TPM_LEFTALIGN, x, y, 0, _hSelf, NULL); } } +void ProjectPanel::showContextMenuFromMenuKey(HTREEITEM selectedItem, int x, int y) +{ + POINT p; + p.x = x; + p.y = y; + + ClientToScreen(_treeView.getHSelf(), &p); + + if (selectedItem != NULL) + { + HMENU hMenu = getMenuHandler(selectedItem); + TrackPopupMenu(hMenu, TPM_LEFTALIGN, p.x, p.y, 0, _hSelf, NULL); + } +} + +HMENU ProjectPanel::getMenuHandler(HTREEITEM selectedItem) +{ + // get clicked item type + NodeType nodeType = getNodeType(selectedItem); + HMENU hMenu = NULL; + + if (nodeType == nodeType_root) + hMenu = _hWorkSpaceMenu; + else if (nodeType == nodeType_project) + hMenu = _hProjectMenu; + else if (nodeType == nodeType_folder) + hMenu = _hFolderMenu; + else //nodeType_file + hMenu = _hFileMenu; + + return hMenu; +} + POINT ProjectPanel::getMenuDisplayPoint(int iButton) { POINT p; diff --git a/PowerEditor/src/WinControls/ProjectPanel/ProjectPanel.h b/PowerEditor/src/WinControls/ProjectPanel/ProjectPanel.h index d2dacf794..b13a21074 100644 --- a/PowerEditor/src/WinControls/ProjectPanel/ProjectPanel.h +++ b/PowerEditor/src/WinControls/ProjectPanel/ProjectPanel.h @@ -135,6 +135,8 @@ protected: bool buildTreeFrom(TiXmlNode *projectRoot, HTREEITEM hParentItem); void notified(LPNMHDR notification); void showContextMenu(int x, int y); + void showContextMenuFromMenuKey(HTREEITEM selectedItem, int x, int y); + HMENU getMenuHandler(HTREEITEM selectedItem); generic_string getAbsoluteFilePath(const TCHAR * relativePath); void openSelectFile(); void setFileExtFilter(FileDialog & fDlg);