diff options
-rw-r--r-- | include/m_srmm_int.h | 1 | ||||
-rw-r--r-- | src/mir_app/src/mir_app.def | 1 | ||||
-rw-r--r-- | src/mir_app/src/mir_app64.def | 1 | ||||
-rw-r--r-- | src/mir_app/src/srmm_base.cpp | 62 |
4 files changed, 25 insertions, 40 deletions
diff --git a/include/m_srmm_int.h b/include/m_srmm_int.h index d1ef3109b5..00f701bc44 100644 --- a/include/m_srmm_int.h +++ b/include/m_srmm_int.h @@ -340,6 +340,7 @@ protected: void onClick_History(CCtrlButton *);
void onClick_CloseQuote(CCtrlButton *);
+ void onContextMenu(CContextMenuPos *);
void onDblClick_List(CCtrlListBox *);
public:
diff --git a/src/mir_app/src/mir_app.def b/src/mir_app/src/mir_app.def index eae8101853..db2c589d2f 100644 --- a/src/mir_app/src/mir_app.def +++ b/src/mir_app/src/mir_app.def @@ -305,6 +305,7 @@ Srmm_FindDialog @406 NONAME ??2CSrmmBaseDialog@@SAPAXI@Z @409 NONAME
??3CSrmmBaseDialog@@SAXPAX@Z @410 NONAME
?isChat@CSrmmBaseDialog@@QBE_NXZ @411 NONAME
+?onContextMenu@CSrmmBaseDialog@@IAEXPAUCContextMenuPos@@@Z @412 NONAME
?RunUserMenu@CSrmmBaseDialog@@IAEXPAUHWND__@@PAUUSERINFO@@ABUtagPOINT@@@Z @414 NONAME
?ClearLog@CSrmmBaseDialog@@QAEXXZ @415 NONAME
?CloseTab@CSrmmBaseDialog@@UAEXXZ @416 NONAME
diff --git a/src/mir_app/src/mir_app64.def b/src/mir_app/src/mir_app64.def index 6811b2d393..f4c00a0a66 100644 --- a/src/mir_app/src/mir_app64.def +++ b/src/mir_app/src/mir_app64.def @@ -305,6 +305,7 @@ Srmm_FindDialog @406 NONAME ??2CSrmmBaseDialog@@SAPEAX_K@Z @409 NONAME
??3CSrmmBaseDialog@@SAXPEAX@Z @410 NONAME
?isChat@CSrmmBaseDialog@@QEBA_NXZ @411 NONAME
+?onContextMenu@CSrmmBaseDialog@@IEAAXPEAUCContextMenuPos@@@Z @412 NONAME
?RunUserMenu@CSrmmBaseDialog@@IEAAXPEAUHWND__@@PEAUUSERINFO@@AEBUtagPOINT@@@Z @414 NONAME
?ClearLog@CSrmmBaseDialog@@QEAAXXZ @415 NONAME
?CloseTab@CSrmmBaseDialog@@UEAAXXZ @416 NONAME
diff --git a/src/mir_app/src/srmm_base.cpp b/src/mir_app/src/srmm_base.cpp index dc4885a68a..3002622535 100644 --- a/src/mir_app/src/srmm_base.cpp +++ b/src/mir_app/src/srmm_base.cpp @@ -66,6 +66,7 @@ CSrmmBaseDialog::CSrmmBaseDialog(CMPluginBase &pPlugin, int idDialog, SESSION_IN m_btnCloseQuote.OnClick = Callback(this, &CSrmmBaseDialog::onClick_CloseQuote);
m_nickList.OnDblClick = Callback(this, &CSrmmBaseDialog::onDblClick_List);
+ m_nickList.OnBuildMenu = Callback(this, &CSrmmBaseDialog::onContextMenu);
timerRedraw.OnEvent = Callback(this, &CSrmmBaseDialog::OnRedrawTimer);
@@ -303,9 +304,9 @@ static void ProcessNickListHovering(const CCtrlListBox &listBox, int hoveredItem ti.rect = clientRect;
CMStringW wszBuf;
- if (auto *ui1 = (USERINFO *)listBox.GetItemData(si->currentHovered)) {
+ if (auto *ui = (USERINFO *)listBox.GetItemData(si->currentHovered)) {
if (ProtoServiceExists(si->pszModule, MS_GC_PROTO_GETTOOLTIPTEXT)) {
- wchar_t *p = (wchar_t*)CallProtoService(si->pszModule, MS_GC_PROTO_GETTOOLTIPTEXT, (WPARAM)si->ptszID, (LPARAM)ui1->pszUID);
+ wchar_t *p = (wchar_t*)CallProtoService(si->pszModule, MS_GC_PROTO_GETTOOLTIPTEXT, (WPARAM)si->ptszID, (LPARAM)ui->pszUID);
if (p != nullptr) {
wszBuf = p;
mir_free(p);
@@ -314,9 +315,9 @@ static void ProcessNickListHovering(const CCtrlListBox &listBox, int hoveredItem if (wszBuf.IsEmpty())
wszBuf.Format(L"%s: %s\r\n%s: %s\r\n%s: %s",
- TranslateT("Nickname"), ui1->pszNick,
- TranslateT("Unique ID"), ui1->pszUID,
- TranslateT("Status"), g_chatApi.TM_WordToString(si->pStatuses, ui1->Status));
+ TranslateT("Nickname"), ui->pszNick,
+ TranslateT("Unique ID"), ui->pszUID,
+ TranslateT("Status"), g_chatApi.TM_WordToString(si->pStatuses, ui->Status));
ti.lpszText = wszBuf.GetBuffer();
}
@@ -329,10 +330,10 @@ void CSrmmBaseDialog::OnNickListTimer(CTimer *pTimer) {
pTimer->Stop();
- if (auto *ui1 = (USERINFO *)m_nickList.SendMsg(LB_GETITEMDATA, m_si->currentHovered, 0)) {
+ if (auto *ui = (USERINFO *)m_nickList.GetItemData(m_si->currentHovered)) {
CMStringW wszBuf;
if (ProtoServiceExists(m_si->pszModule, MS_GC_PROTO_GETTOOLTIPTEXT)) {
- wchar_t *p = (wchar_t *)CallProtoService(m_si->pszModule, MS_GC_PROTO_GETTOOLTIPTEXT, (WPARAM)m_si->ptszID, (LPARAM)ui1->pszUID);
+ wchar_t *p = (wchar_t *)CallProtoService(m_si->pszModule, MS_GC_PROTO_GETTOOLTIPTEXT, (WPARAM)m_si->ptszID, (LPARAM)ui->pszUID);
if (p) {
wszBuf = p;
mir_free(p);
@@ -340,9 +341,9 @@ void CSrmmBaseDialog::OnNickListTimer(CTimer *pTimer) }
if (wszBuf.IsEmpty())
wszBuf.Format(L"<b>%s:</b>\t%s\n<b>%s:</b>\t%s\n<b>%s:</b>\t%s",
- TranslateT("Nick"), ui1->pszNick,
- TranslateT("Unique ID"), ui1->pszUID,
- TranslateT("Status"), g_chatApi.TM_WordToString(m_si->pStatuses, ui1->Status));
+ TranslateT("Nick"), ui->pszNick,
+ TranslateT("Unique ID"), ui->pszUID,
+ TranslateT("Status"), g_chatApi.TM_WordToString(m_si->pStatuses, ui->Status));
CLCINFOTIP ti = { sizeof(ti) };
Tipper_ShowTip(wszBuf, &ti);
@@ -452,36 +453,6 @@ LRESULT CSrmmBaseDialog::WndProc_Nicklist(UINT msg, WPARAM wParam, LPARAM lParam }
return 1;
- case WM_CONTEXTMENU:
- POINT pt;
- {
- int height = 0;
- pt.x = GET_X_LPARAM(lParam);
- pt.y = GET_Y_LPARAM(lParam);
- if (pt.x == -1 && pt.y == -1) {
- int index = m_nickList.GetCurSel();
- int top = m_nickList.SendMsg(LB_GETTOPINDEX, 0, 0);
- height = m_nickList.SendMsg(LB_GETITEMHEIGHT, 0, 0);
- pt.x = 4;
- pt.y = (index - top)*height + 1;
- }
- else ScreenToClient(m_nickList.GetHwnd(), &pt);
-
- int item = m_nickList.SendMsg(LB_ITEMFROMPOINT, 0, MAKELPARAM(pt.x, pt.y));
- if (HIWORD(item) != 0) // clicked outside the client area
- break;
-
- if (auto *ui = (USERINFO *)m_nickList.GetItemData(item)) {
- if (pt.x == -1 && pt.y == -1)
- pt.y += height - 4;
- ClientToScreen(m_nickList.GetHwnd(), &pt);
-
- RunUserMenu(m_nickList.GetHwnd(), ui, pt);
- return TRUE;
- }
- }
- break;
-
case WM_KEYDOWN:
if (wParam == VK_RETURN) {
int index = m_nickList.GetCurSel();
@@ -943,6 +914,17 @@ void CSrmmBaseDialog::onClick_CloseQuote(CCtrlButton*) Resize();
}
+void CSrmmBaseDialog::onContextMenu(CContextMenuPos *pos)
+{
+ POINT pt = pos->pt;
+ ScreenToClient(m_nickList.GetHwnd(), &pt);
+
+ int item = m_nickList.SendMsg(LB_ITEMFROMPOINT, 0, MAKELPARAM(pt.x, pt.y));
+ if (HIWORD(item) == 0) // clicked inside the client area
+ if (auto *ui = (USERINFO *)m_nickList.GetItemData(item))
+ RunUserMenu(m_nickList.GetHwnd(), ui, pos->pt);
+}
+
void CSrmmBaseDialog::onDblClick_List(CCtrlListBox *pList)
{
TVHITTESTINFO hti;
|