From 09768fdb0f9de1927ff55292af87714eceefb562 Mon Sep 17 00:00:00 2001 From: George Hazan Date: Fri, 30 Dec 2016 23:14:49 +0300 Subject: fixes #661 (Scriver: Cannot send message if "Send Message" button not set in Toolbar) --- include/m_message.h | 6 +++--- plugins/Scriver/src/msgs.cpp | 2 +- src/mir_app/src/srmm_toolbar.cpp | 24 +++++++++++++++--------- src/mir_core/src/ui_utils.cpp | 5 ++++- 4 files changed, 23 insertions(+), 14 deletions(-) diff --git a/include/m_message.h b/include/m_message.h index 10642becf7..c9bbf34910 100644 --- a/include/m_message.h +++ b/include/m_message.h @@ -233,8 +233,8 @@ struct StatusIconClickData #define BBBF_ISRSIDEBUTTON (1<<7) #define BBBF_CANBEHIDDEN (1<<8) #define BBBF_ISSEPARATOR (1<<9) - -#define BBBF_CREATEBYID (1<<11) //only for tabsrmm internal use +#define BBBF_CANTBEHIDDEN (1<<10) +#define BBBF_CREATEBYID (1<<11) // only for the internal use struct BBButton { @@ -346,7 +346,7 @@ struct CustomButtonData : public MZeroedObject HANDLE m_hIcon; // Handle to icolib registred icon bool m_bIMButton, m_bChatButton; - bool m_bCanBeHidden, m_bHidden, m_bAutoHidden, m_bSeparator, m_bDisabled, m_bPushButton; + bool m_bCanBeHidden, m_bCantBeHidden, m_bHidden, m_bAutoHidden, m_bSeparator, m_bDisabled, m_bPushButton; bool m_bRSided; BYTE m_opFlags; int m_hLangpack; diff --git a/plugins/Scriver/src/msgs.cpp b/plugins/Scriver/src/msgs.cpp index db483297bd..2857737506 100644 --- a/plugins/Scriver/src/msgs.cpp +++ b/plugins/Scriver/src/msgs.cpp @@ -429,7 +429,7 @@ int RegisterToolbarIcons(WPARAM, LPARAM) { BBButton bbd = {}; bbd.pszModuleName = "SRMM"; - bbd.bbbFlags = BBBF_ISCHATBUTTON | BBBF_ISIMBUTTON | BBBF_CREATEBYID | BBBF_ISRSIDEBUTTON; + bbd.bbbFlags = BBBF_ISCHATBUTTON | BBBF_ISIMBUTTON | BBBF_CREATEBYID | BBBF_ISRSIDEBUTTON | BBBF_CANTBEHIDDEN; bbd.dwButtonID = IDOK; bbd.dwDefPos = 5; bbd.hIcon = IcoLib_GetIconHandle("scriver_SEND"); diff --git a/src/mir_app/src/srmm_toolbar.cpp b/src/mir_app/src/srmm_toolbar.cpp index 557fa8b248..ef3238c128 100644 --- a/src/mir_app/src/srmm_toolbar.cpp +++ b/src/mir_app/src/srmm_toolbar.cpp @@ -130,6 +130,7 @@ MIR_APP_DLL(int) Srmm_AddButton(const BBButton *bbdi, int _hLang) cbd->m_bHidden = (bbdi->bbbFlags & BBBF_HIDDEN) != 0; cbd->m_bRSided = (bbdi->bbbFlags & BBBF_ISRSIDEBUTTON) != 0; cbd->m_bCanBeHidden = (bbdi->bbbFlags & BBBF_CANBEHIDDEN) != 0; + cbd->m_bCantBeHidden = (bbdi->bbbFlags & BBBF_CANTBEHIDDEN) != 0; cbd->m_bSeparator = (bbdi->bbbFlags & BBBF_ISSEPARATOR) != 0; cbd->m_bChatButton = (bbdi->bbbFlags & BBBF_ISCHATBUTTON) != 0; cbd->m_bIMButton = (bbdi->bbbFlags & BBBF_ISIMBUTTON) != 0; @@ -462,6 +463,7 @@ class CSrmmToolbarOptions : public CDlgBase cbd->m_bChatButton = (cbd->m_opFlags & BBSF_CHATBUTTON) != 0; cbd->m_bCanBeHidden = (cbd->m_opFlags & BBSF_CANBEHIDDEN) != 0; } + if (RSide && !cbd->m_bRSided) { cbd->m_bRSided = true; cbd->m_opFlags |= BBSF_NTBSWAPED; @@ -470,7 +472,8 @@ class CSrmmToolbarOptions : public CDlgBase cbd->m_bRSided = false; cbd->m_opFlags |= BBSF_NTBSWAPED; } - if (!m_toolBar.GetCheckState(tvi.hItem)) { + + if (!cbd->m_bCantBeHidden && !m_toolBar.GetCheckState(tvi.hItem)) { cbd->m_bIMButton = false; cbd->m_bChatButton = false; @@ -481,7 +484,7 @@ class CSrmmToolbarOptions : public CDlgBase if (!cbd->m_bIMButton && !cbd->m_bChatButton) cbd->m_bIMButton = true; if (cbd->m_bSeparator && !mir_strcmp(cbd->m_pszModuleName, "Tabsrmm_sep")) { - cbd->m_bHidden = 0; + cbd->m_bHidden = false; cbd->m_opFlags &= ~BBSF_NTBDESTRUCT; ++loc_sepcout; } @@ -537,13 +540,14 @@ class CSrmmToolbarOptions : public CDlgBase TVINSERTSTRUCT tvis2 = {}; tvis.hInsertAfter = TVI_LAST; - tvis2.item.mask = TVIF_PARAM | TVIF_TEXT | TVIF_SELECTEDIMAGE | TVIF_IMAGE | TVIF_STATE; - tvis2.item.pszText = MIDDLE_SEPARATOR; - tvis2.item.stateMask = TVIS_BOLD; - tvis2.item.state = TVIS_BOLD; - tvis2.item.iImage = tvis.item.iSelectedImage = -1; + tvis2.itemex.mask = TVIF_PARAM | TVIF_TEXT | TVIF_SELECTEDIMAGE | TVIF_IMAGE | TVIF_STATE | TVIF_STATEEX; + tvis2.itemex.pszText = MIDDLE_SEPARATOR; + tvis2.itemex.stateMask = TVIS_BOLD; + tvis2.itemex.state = TVIS_BOLD; + tvis2.itemex.iImage = tvis.item.iSelectedImage = -1; + tvis2.itemex.uStateEx = TVIS_EX_DISABLED; tvis.hInsertAfter = hti = m_toolBar.InsertItem(&tvis2); - m_toolBar.SetCheckState(hti, 1); + m_toolBar.SetItemState(hti, 0x3000, TVIS_STATEIMAGEMASK); } tvis.item.lParam = (LPARAM)cbd; @@ -561,6 +565,8 @@ class CSrmmToolbarOptions : public CDlgBase hti = m_toolBar.InsertItem(&tvis); m_toolBar.SetCheckState(hti, (cbd->m_bIMButton || cbd->m_bChatButton)); + if (cbd->m_bCantBeHidden) + m_toolBar.SetItemState(hti, 0x3000, TVIS_STATEIMAGEMASK); } } @@ -684,7 +690,7 @@ public: CustomButtonData *cbd = (CustomButtonData*)tvi.lParam; cbd->m_bIMButton = m_btnIM.GetState() != 0; cbd->m_bChatButton = m_btnChat.GetState() != 0; - cbd->m_bCanBeHidden = m_btnHidden.GetState() != 0; + cbd->m_bCanBeHidden = !cbd->m_bCantBeHidden && m_btnHidden.GetState() != 0; cbd->m_opFlags = (cbd->m_bIMButton ? BBSF_IMBUTTON : 0) + (cbd->m_bChatButton ? BBSF_CHATBUTTON : 0) + (cbd->m_bCanBeHidden ? BBSF_CANBEHIDDEN : 0); } diff --git a/src/mir_core/src/ui_utils.cpp b/src/mir_core/src/ui_utils.cpp index 1e4cec81b9..6022c498e9 100644 --- a/src/mir_core/src/ui_utils.cpp +++ b/src/mir_core/src/ui_utils.cpp @@ -1785,11 +1785,14 @@ BOOL CCtrlTreeView::OnNotify(int, NMHDR *pnmh) void CCtrlTreeView::InvertCheck(HTREEITEM hItem) { TVITEMEX tvi; - tvi.mask = TVIF_HANDLE | TVIF_IMAGE | TVIF_SELECTEDIMAGE | TVIF_PARAM; + tvi.mask = TVIF_HANDLE | TVIF_IMAGE | TVIF_SELECTEDIMAGE | TVIF_PARAM | TVIF_STATEEX; tvi.hItem = hItem; if (!GetItem(&tvi)) return; + if (tvi.uStateEx & TVIS_EX_DISABLED) + return; + tvi.iImage = tvi.iSelectedImage = !tvi.iImage; SetItem(&tvi); -- cgit v1.2.3