summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRozhuk Ivan <rozhuk.im@gmail.com>2014-03-07 14:50:41 +0000
committerRozhuk Ivan <rozhuk.im@gmail.com>2014-03-07 14:50:41 +0000
commit83cf0514b2f7a463c92444258fa0b8752d9e2cd9 (patch)
treedc5d503cbb12a8820099af71d8d2c29a2f76b178
parent7cd8f6ec7632a697bc52ed2509981bfae3873be9 (diff)
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
-rw-r--r--plugins/WhenWasIt/src/dlg_handlers.cpp40
-rw-r--r--protocols/MRA/src/MraProto.h8
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<CMraProto>
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<MraGroupItem> m_groups;