From 83cf0514b2f7a463c92444258fa0b8752d9e2cd9 Mon Sep 17 00:00:00 2001 From: Rozhuk Ivan Date: Fri, 7 Mar 2014 14:50:41 +0000 Subject: WhenWasIt + Add: Contact menu in "Upcoming birthsdays" and "Birthday list" * Fix: Duplicate entries in "Upcoming birthsdays" git-svn-id: http://svn.miranda-ng.org/main/trunk@8448 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c --- plugins/WhenWasIt/src/dlg_handlers.cpp | 40 ++++++++++++++++++++++++++++++---- protocols/MRA/src/MraProto.h | 8 ++++--- 2 files changed, 41 insertions(+), 7 deletions(-) diff --git a/plugins/WhenWasIt/src/dlg_handlers.cpp b/plugins/WhenWasIt/src/dlg_handlers.cpp index 3fb1dbf078..9c84c46af3 100644 --- a/plugins/WhenWasIt/src/dlg_handlers.cpp +++ b/plugins/WhenWasIt/src/dlg_handlers.cpp @@ -636,6 +636,11 @@ int UpdateBirthdayEntry(HWND hList, MCONTACT hContact, int entry, int bShowAll, static LRESULT CALLBACK BirthdaysListSubclassProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam) { + LVITEM item = { 0 }; + POINT pt = { 0 }; + MCONTACT hContact; + int i, count; + switch (msg) { case WM_KEYUP: if (wParam == VK_ESCAPE) @@ -648,16 +653,35 @@ static LRESULT CALLBACK BirthdaysListSubclassProc(HWND hWnd, UINT msg, WPARAM wP break; case WM_LBUTTONDBLCLK: - int count = ListView_GetItemCount(hWnd); - MCONTACT hContact; - LVITEM item = { 0 }; + count = ListView_GetItemCount(hWnd); item.mask = LVIF_PARAM; - for (int i = 0; i < count; i++) { + for (i = 0; i < count; i++) { if (ListView_GetItemState(hWnd, i, LVIS_SELECTED)) { item.iItem = i; ListView_GetItem(hWnd, &item); hContact = (MCONTACT)item.lParam; CallService(MS_WWI_ADD_BIRTHDAY, hContact, 0); + break; + } + } + break; + + case WM_CONTEXTMENU: + pt.x = (short)LOWORD(lParam); + pt.y = (short)HIWORD(lParam); + count = ListView_GetItemCount(hWnd); + item.mask = LVIF_PARAM; + for (i = 0; i < count; i++) { + if (ListView_GetItemState(hWnd, i, LVIS_SELECTED)) { + item.iItem = i; + ListView_GetItem(hWnd, &item); + hContact = (MCONTACT)item.lParam; + HMENU hMenu = (HMENU)CallService(MS_CLIST_MENUBUILDCONTACT, (WPARAM)hContact, 0); + if (hMenu != NULL) { + TrackPopupMenu(hMenu, TPM_RIGHTBUTTON, pt.x, pt.y, 0, hWnd, NULL); + DestroyMenu(hMenu); + } + break; } } break; @@ -856,6 +880,7 @@ INT_PTR CALLBACK DlgProcUpcoming(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lPar SendMessage(hWnd, WM_SETICON, ICON_BIG, (LPARAM)Skin_GetIconByHandle(hListMenu)); HWND hList = GetDlgItem(hWnd, IDC_UPCOMING_LIST); + mir_subclassWindow(hList, BirthdaysListSubclassProc); ListView_SetExtendedListViewStyleEx(hList, LVS_EX_FULLROWSELECT, LVS_EX_FULLROWSELECT); LVCOLUMN col; @@ -894,6 +919,13 @@ INT_PTR CALLBACK DlgProcUpcoming(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lPar HWND hList = GetDlgItem(hWnd, IDC_UPCOMING_LIST); LVITEM item = { 0 }; + LVFINDINFO fi = { 0 }; + + fi.flags = LVFI_PARAM; + fi.lParam = (LPARAM)data->dtb; + if (-1 != ListView_FindItem(hList, -1, &fi)) + return 0; /* Allready in list. */ + int index = ListView_GetItemCount(hList); item.iItem = index; item.mask = LVIF_PARAM | LVIF_TEXT; diff --git a/protocols/MRA/src/MraProto.h b/protocols/MRA/src/MraProto.h index 690e19e563..cc732bc19d 100644 --- a/protocols/MRA/src/MraProto.h +++ b/protocols/MRA/src/MraProto.h @@ -171,9 +171,11 @@ struct CMraProto : public PROTO HANDLE m_heNudgeReceived; HANDLE m_hConnection; - DWORD m_dwThreadWorkerLastPingTime, m_dwNextPingSendTickTime, m_dwPingPeriod; - DWORD m_dwThreadWorkerRunning; - DWORD dwCMDNum; + DWORD m_dwNextPingSendTickTime; + DWORD m_dwPingPeriod; + volatile DWORD m_dwThreadWorkerLastPingTime; + volatile DWORD m_dwThreadWorkerRunning; + volatile DWORD dwCMDNum; OBJLIST m_groups; -- cgit v1.2.3