diff options
Diffstat (limited to 'plugins/MenuItemEx/src/options.cpp')
-rw-r--r-- | plugins/MenuItemEx/src/options.cpp | 160 |
1 files changed, 95 insertions, 65 deletions
diff --git a/plugins/MenuItemEx/src/options.cpp b/plugins/MenuItemEx/src/options.cpp index 13512fff96..7395585672 100644 --- a/plugins/MenuItemEx/src/options.cpp +++ b/plugins/MenuItemEx/src/options.cpp @@ -26,81 +26,111 @@ static const checkboxes[] = { { IDC_TRIMID, VF_TRIMID }
};
-INT_PTR CALLBACK OptionsProc(HWND hdlg, UINT msg, WPARAM wparam, LPARAM lparam)
+COptDialog::COptDialog() :
+ CDlgBase(g_plugin, IDD_OPTIONS),
+ m_chkVis(this, IDC_VIS),
+ m_chkAlpha(this, IDC_SHOWALPHAICONS),
+ m_chkHide(this, IDC_HIDE),
+ m_chkIgnore(this, IDC_IGNORE),
+ m_chkProtos(this, IDC_PROTOS),
+ m_chkAdded(this, IDC_ADDED),
+ m_chkAuthReq(this, IDC_AUTHREQ),
+ m_chkRecvFiles(this, IDC_RECVFILES),
+ m_chkCopyIP(this, IDC_COPYIP),
+ m_chkCopyMirver(this, IDC_COPYMIRVER),
+ m_chkStatusMsg(this, IDC_STATUSMSG),
+ m_chkSMName(this, IDC_SMNAME),
+ m_chkCopyID(this, IDC_COPYID),
+ m_chkCopyIDName(this, IDC_COPYIDNAME),
+ m_chkShowID(this, IDC_SHOWID),
+ m_chkTrimID(this, IDC_TRIMID),
+ m_lblHint(this, IDC_HINT1),
+ m_chkIgnoreHide(this, IDC_IGNOREHIDE)
{
- DWORD flags = g_plugin.getDword("flags", vf_default);
- wchar_t buffer[64] = { 0 };
- int i;
-
- switch (msg) {
- case WM_INITDIALOG:
- TranslateDialogDefault(hdlg);
-
- for (auto &it : checkboxes)
- CheckDlgButton(hdlg, it.idc, (flags & it.flag) ? BST_CHECKED : BST_UNCHECKED);
-
- if (bPopupService) {
- for (i = 0; i < 4; i++) {
- GetDlgItemText(hdlg, checkboxes[i].idc, buffer, (_countof(buffer) - 3));
- mir_wstrcat(buffer, L" *");
- SetDlgItemText(hdlg, checkboxes[i].idc, buffer);
- }
- }
- else ShowWindow(GetDlgItem(hdlg, IDC_HINT1), SW_HIDE);
-
- SendMessage(hdlg, WM_USER + 50, 0, 0);
- return 0;
-
- case WM_USER + 50:
- EnableWindow(GetDlgItem(hdlg, IDC_SHOWALPHAICONS), IsDlgButtonChecked(hdlg, IDC_VIS) == BST_CHECKED);
- EnableWindow(GetDlgItem(hdlg, IDC_IGNOREHIDE), IsDlgButtonChecked(hdlg, IDC_IGNORE) == BST_CHECKED);
- EnableWindow(GetDlgItem(hdlg, IDC_COPYIDNAME), IsDlgButtonChecked(hdlg, IDC_COPYID) == BST_CHECKED);
- EnableWindow(GetDlgItem(hdlg, IDC_SHOWID), IsDlgButtonChecked(hdlg, IDC_COPYID) == BST_CHECKED);
- EnableWindow(GetDlgItem(hdlg, IDC_TRIMID), (IsDlgButtonChecked(hdlg, IDC_COPYID) == BST_CHECKED && IsDlgButtonChecked(hdlg, IDC_SHOWID) == BST_CHECKED));
- EnableWindow(GetDlgItem(hdlg, IDC_SMNAME), IsDlgButtonChecked(hdlg, IDC_STATUSMSG) == BST_CHECKED);
- return 1;
-
- case WM_NOTIFY:
- switch (((LPNMHDR)lparam)->code) {
- case PSN_APPLY:
- DWORD mod_flags = 0;
-
- for (auto &it : checkboxes)
- mod_flags |= IsDlgButtonChecked(hdlg, it.idc) ? it.flag : 0;
-
- g_plugin.setDword("flags", mod_flags);
- return 1;
- }
- break;
-
- case WM_COMMAND:
- if (HIWORD(wparam) == BN_CLICKED && GetFocus() == (HWND)lparam) {
- SendMessage(GetParent(hdlg), PSM_CHANGED, 0, 0);
- if (LOWORD(wparam) == IDC_VIS ||
- LOWORD(wparam) == IDC_IGNORE ||
- LOWORD(wparam) == IDC_COPYID ||
- LOWORD(wparam) == IDC_STATUSMSG ||
- LOWORD(wparam) == IDC_SHOWID)
- {
- SendMessage(hdlg, WM_USER + 50, 0, 0);
- }
+ m_flags = g_plugin.getDword("flags", vf_default);
+
+ m_chkVis.OnChange = Callback(this, &COptDialog::OnVisChange);
+ m_chkIgnore.OnChange = Callback(this, &COptDialog::OnIgnoreChange);
+ m_chkCopyID.OnChange = Callback(this, &COptDialog::OnCopyIDChange);
+ m_chkStatusMsg.OnChange = Callback(this, &COptDialog::OnStatusMsgChange);
+ m_chkShowID.OnChange = Callback(this, &COptDialog::OnShowIDChange);
+}
+
+bool COptDialog::OnInitDialog()
+{
+ for (auto &it : checkboxes) {
+ CCtrlCheck &item = *(CCtrlCheck*)FindControl(it.idc);
+ item.SetState(m_flags & it.flag);
+ }
+
+ if (bPopupService) {
+ for (int i = 0; i < 4; i++) {
+ CCtrlCheck &item = *(CCtrlCheck*)FindControl(checkboxes[i].idc);
+ CMStringW buffer;
+ buffer.Format(L"%s *", item.GetText());
+ item.SetText(buffer);
}
- return 0;
+ }
+ else
+ m_lblHint.Hide();
- case WM_CLOSE:
- EndDialog(hdlg, 0);
- return 0;
+ EnableWindowChecks();
+ return true;
+}
+
+bool COptDialog::OnApply()
+{
+ DWORD mod_flags = 0;
+
+ for (auto &it : checkboxes) {
+ CCtrlCheck &item = *(CCtrlCheck*)FindControl(it.idc);
+ mod_flags |= item.GetState() ? it.flag : 0;
}
- return 0;
+
+ g_plugin.setDword("flags", mod_flags);
+ return true;
+}
+
+void COptDialog::EnableWindowChecks()
+{
+ m_chkAlpha.Enable(m_chkVis.GetState());
+ m_chkIgnoreHide.Enable(m_chkIgnore.GetState());
+ m_chkCopyIDName.Enable(m_chkCopyID.GetState());
+ m_chkShowID.Enable(m_chkCopyID.GetState());
+ m_chkTrimID.Enable(m_chkCopyID.GetState() && m_chkShowID.GetState());
+ m_chkSMName.Enable(m_chkStatusMsg.GetState());
+}
+
+void COptDialog::OnVisChange(CCtrlBase*)
+{
+ EnableWindowChecks();
+}
+
+void COptDialog::OnIgnoreChange(CCtrlBase*)
+{
+ EnableWindowChecks();
+}
+
+void COptDialog::OnCopyIDChange(CCtrlBase*)
+{
+ EnableWindowChecks();
+}
+
+void COptDialog::OnStatusMsgChange(CCtrlBase*)
+{
+ EnableWindowChecks();
+}
+
+void COptDialog::OnShowIDChange(CCtrlBase*)
+{
+ EnableWindowChecks();
}
int OptionsInit(WPARAM wparam, LPARAM)
{
OPTIONSDIALOGPAGE odp = {};
- odp.position = 955000000;
- odp.pszTemplate = MAKEINTRESOURCEA(IDD_OPTIONS);
odp.szTitle.a = MODULENAME;
- odp.pfnDlgProc = OptionsProc;
+ odp.pDialog = new COptDialog;
odp.szGroup.a = LPGEN("Customize");
odp.flags = ODPF_BOLDGROUPS;
g_plugin.addOptions(wparam, &odp);
|