From d9a9586ebc82cafbd1c9bfd12425c49351743a64 Mon Sep 17 00:00:00 2001 From: Jun Tajima <56220423+tjmprm77@users.noreply.github.com> Date: Sun, 15 Oct 2023 21:44:12 +0900 Subject: [PATCH] Modify the "Substitution Filters" dialog. - Disable the "Remove" button when no item is selected. - Disable the "Clear" button when no items are registered in the list. --- Src/SubstitutionFiltersDlg.cpp | 41 ++++++++++++++++++++++++++++++++++ Src/SubstitutionFiltersDlg.h | 3 +++ 2 files changed, 44 insertions(+) diff --git a/Src/SubstitutionFiltersDlg.cpp b/Src/SubstitutionFiltersDlg.cpp index e2336361fa5..200db2e00e8 100644 --- a/Src/SubstitutionFiltersDlg.cpp +++ b/Src/SubstitutionFiltersDlg.cpp @@ -51,6 +51,7 @@ BEGIN_MESSAGE_MAP(SubstitutionFiltersDlg, CTrPropertyPage) ON_BN_CLICKED(IDC_LFILTER_ADDBTN, OnBnClickedAddBtn) ON_BN_CLICKED(IDC_LFILTER_CLEARBTN, OnBnClickedClearBtn) ON_BN_CLICKED(IDC_LFILTER_REMOVEBTN, OnBnClickedRemovebtn) + ON_NOTIFY(LVN_ITEMCHANGED, IDC_SUBSTITUTION_FILTERS, OnLvnItemChangedSubstitutionFilterList) //}}AFX_MSG_MAP END_MESSAGE_MAP() @@ -68,6 +69,8 @@ BOOL SubstitutionFiltersDlg::OnInitDialog() InitList(); + SetButtonState(); + return TRUE; // return TRUE unless you set the focus to a control // EXCEPTION: OCX Property Pages should return FALSE } @@ -145,6 +148,8 @@ void SubstitutionFiltersDlg::OnBnClickedAddBtn() void SubstitutionFiltersDlg::OnBnClickedClearBtn() { m_listFilters.DeleteAllItems(); + + SetButtonState(); } /** @@ -211,4 +216,40 @@ void SubstitutionFiltersDlg::OnBnClickedRemovebtn() bool bPartialOk = false; m_listFilters.EnsureVisible(newSel, bPartialOk); } + + SetButtonState(); +} + +/** + * @brief Called when item state is changed. + * + * Set the state of the "Remove" and "Clear" buttons. + * @param [in] pNMHDR Listview item data. + * @param [out] pResult Result of the action is returned in here. + */ +void SubstitutionFiltersDlg::OnLvnItemChangedSubstitutionFilterList(NMHDR* pNMHDR, LRESULT* pResult) +{ + LPNMLISTVIEW pNMLV = reinterpret_cast(pNMHDR); + if ((pNMLV->uOldState & LVIS_SELECTED) != (pNMLV->uNewState & LVIS_SELECTED)) + { + SetButtonState(); + } + *pResult = 0; +} + +/** + * @brief Set the state of the "Remove" and "Clear" buttons. + * + * Disable the "Remove" button when no item is selected. + * Disable the "Clear" button when no item is registered in the list. + */ +void SubstitutionFiltersDlg::SetButtonState() +{ + int sel = -1; + sel = m_listFilters.GetNextItem(sel, LVNI_SELECTED); + bool enabled = (sel != -1); + EnableDlgItem(IDC_LFILTER_REMOVEBTN, enabled); + + enabled = (m_listFilters.GetItemCount() > 0); + EnableDlgItem(IDC_LFILTER_CLEARBTN, enabled); } diff --git a/Src/SubstitutionFiltersDlg.h b/Src/SubstitutionFiltersDlg.h index a10b1700a6d..7fd0218d67b 100644 --- a/Src/SubstitutionFiltersDlg.h +++ b/Src/SubstitutionFiltersDlg.h @@ -45,6 +45,7 @@ class SubstitutionFiltersDlg : public CTrPropertyPage afx_msg void OnBnClickedAddBtn(); afx_msg void OnBnClickedClearBtn(); afx_msg void OnBnClickedRemovebtn(); + afx_msg void OnLvnItemChangedSubstitutionFilterList(NMHDR* pNMHDR, LRESULT* pResult); //}}AFX_MSG DECLARE_MESSAGE_MAP() @@ -54,4 +55,6 @@ class SubstitutionFiltersDlg : public CTrPropertyPage CSubeditList m_listFilters; /**< List control having filter strings */ SubstitutionFiltersList *m_pSubstitutionFiltersList; + + void SetButtonState(); };