From 8d2e705a61eef67420da795ca1729b5d21b5675d Mon Sep 17 00:00:00 2001 From: George Hazan Date: Thu, 8 Sep 2022 11:44:53 -0700 Subject: fixes #3187 (VoiceService: hide auto actions settings page if we do not have accounts with VOIP enabled) --- plugins/VoiceService/src/options.cpp | 123 ++++++++++++++++++----------------- 1 file changed, 63 insertions(+), 60 deletions(-) (limited to 'plugins/VoiceService/src/options.cpp') diff --git a/plugins/VoiceService/src/options.cpp b/plugins/VoiceService/src/options.cpp index bf669725fc..f4613bdec8 100644 --- a/plugins/VoiceService/src/options.cpp +++ b/plugins/VoiceService/src/options.cpp @@ -83,59 +83,51 @@ static INT_PTR CALLBACK PopupsDlgProc(HWND hwndDlg, UINT msg, WPARAM wParam, LPA { switch (msg) { case WM_INITDIALOG: - { - SendDlgItemMessage(hwndDlg, IDC_RIGHT_ACTION, CB_ADDSTRING, 0, (LPARAM)TranslateT("Do nothing")); - SendDlgItemMessage(hwndDlg, IDC_RIGHT_ACTION, CB_ADDSTRING, 0, (LPARAM)TranslateT("Close popup")); + SendDlgItemMessage(hwndDlg, IDC_RIGHT_ACTION, CB_ADDSTRING, 0, (LPARAM)TranslateT("Do nothing")); + SendDlgItemMessage(hwndDlg, IDC_RIGHT_ACTION, CB_ADDSTRING, 0, (LPARAM)TranslateT("Close popup")); - SendDlgItemMessage(hwndDlg, IDC_LEFT_ACTION, CB_ADDSTRING, 0, (LPARAM)TranslateT("Do nothing")); - SendDlgItemMessage(hwndDlg, IDC_LEFT_ACTION, CB_ADDSTRING, 0, (LPARAM)TranslateT("Close popup")); + SendDlgItemMessage(hwndDlg, IDC_LEFT_ACTION, CB_ADDSTRING, 0, (LPARAM)TranslateT("Do nothing")); + SendDlgItemMessage(hwndDlg, IDC_LEFT_ACTION, CB_ADDSTRING, 0, (LPARAM)TranslateT("Close popup")); - // Needs to be called here in this case + // Needs to be called here in this case + { BOOL ret = SaveOptsDlgProc(popupsControls, _countof(popupsControls), MODULE_NAME, hwndDlg, msg, wParam, lParam); - PopupsEnableDisableCtrls(hwndDlg); - return ret; } + case WM_COMMAND: - { - switch (LOWORD(wParam)) { - case IDC_POPUPS: - case IDC_WINCOLORS: - case IDC_DEFAULTCOLORS: - case IDC_DELAYFROMPU: - case IDC_DELAYPERMANENT: - case IDC_DELAYCUSTOM: - { - if (HIWORD(wParam) == BN_CLICKED) - PopupsEnableDisableCtrls(hwndDlg); - - break; - } - case IDC_PREV: - { - Options op = opts; - - if (IsDlgButtonChecked(hwndDlg, IDC_DELAYFROMPU)) - op.popup_delay_type = POPUP_DELAY_DEFAULT; - else if (IsDlgButtonChecked(hwndDlg, IDC_DELAYCUSTOM)) - op.popup_delay_type = POPUP_DELAY_CUSTOM; - else if (IsDlgButtonChecked(hwndDlg, IDC_DELAYPERMANENT)) - op.popup_delay_type = POPUP_DELAY_PERMANENT; - - op.popup_timeout = GetDlgItemInt(hwndDlg, IDC_DELAY, NULL, FALSE); - op.popup_bkg_color = SendDlgItemMessage(hwndDlg, IDC_BGCOLOR, CPM_GETCOLOUR, 0, 0); - op.popup_text_color = SendDlgItemMessage(hwndDlg, IDC_TEXTCOLOR, CPM_GETCOLOUR, 0, 0); - op.popup_use_win_colors = IsDlgButtonChecked(hwndDlg, IDC_WINCOLORS) != 0; - op.popup_use_default_colors = IsDlgButtonChecked(hwndDlg, IDC_DEFAULTCOLORS) != 0; - - ShowTestPopup(TranslateT("Test Contact"), TranslateT("Test description"), &op); - - break; - } - } + switch (LOWORD(wParam)) { + case IDC_POPUPS: + case IDC_WINCOLORS: + case IDC_DEFAULTCOLORS: + case IDC_DELAYFROMPU: + case IDC_DELAYPERMANENT: + case IDC_DELAYCUSTOM: + if (HIWORD(wParam) == BN_CLICKED) + PopupsEnableDisableCtrls(hwndDlg); + break; + + case IDC_PREV: + Options op = opts; + + if (IsDlgButtonChecked(hwndDlg, IDC_DELAYFROMPU)) + op.popup_delay_type = POPUP_DELAY_DEFAULT; + else if (IsDlgButtonChecked(hwndDlg, IDC_DELAYCUSTOM)) + op.popup_delay_type = POPUP_DELAY_CUSTOM; + else if (IsDlgButtonChecked(hwndDlg, IDC_DELAYPERMANENT)) + op.popup_delay_type = POPUP_DELAY_PERMANENT; + + op.popup_timeout = GetDlgItemInt(hwndDlg, IDC_DELAY, NULL, FALSE); + op.popup_bkg_color = SendDlgItemMessage(hwndDlg, IDC_BGCOLOR, CPM_GETCOLOUR, 0, 0); + op.popup_text_color = SendDlgItemMessage(hwndDlg, IDC_TEXTCOLOR, CPM_GETCOLOUR, 0, 0); + op.popup_use_win_colors = IsDlgButtonChecked(hwndDlg, IDC_WINCOLORS) != 0; + op.popup_use_default_colors = IsDlgButtonChecked(hwndDlg, IDC_DEFAULTCOLORS) != 0; + + ShowTestPopup(TranslateT("Test Contact"), TranslateT("Test description"), &op); break; } + break; } return SaveOptsDlgProc(popupsControls, _countof(popupsControls), MODULE_NAME, hwndDlg, msg, wParam, lParam); @@ -340,24 +332,35 @@ public: ///////////////////////////////////////////////////////////////////////////////////////// +static bool IsModuleEnabled() +{ + for (auto& cc : Contacts()) + if (CanCall(cc, FALSE)) + return true; + + return false; +} + int InitOptionsCallback(WPARAM wParam, LPARAM) { - OPTIONSDIALOGPAGE odp; - ZeroMemory(&odp, sizeof(odp)); - odp.pPlugin = &g_plugin; - odp.flags = ODPF_BOLDGROUPS; - - odp.szGroup.a = LPGEN("Popups"); - odp.szTitle.a = LPGEN("Voice Calls"); - odp.pfnDlgProc = PopupsDlgProc; - odp.pszTemplate = MAKEINTRESOURCEA(IDD_POPUPS); - g_plugin.addOptions(wParam, &odp); - - ZeroMemory(&odp, sizeof(odp)); - odp.szGroup.a = LPGEN("Voice Calls"); - odp.szTitle.a = LPGEN("Auto actions"); - odp.pDialog = new CAutoOptsDlg(); - g_plugin.addOptions(wParam, &odp); + if (IsModuleEnabled()) { + OPTIONSDIALOGPAGE odp; + ZeroMemory(&odp, sizeof(odp)); + odp.pPlugin = &g_plugin; + odp.flags = ODPF_BOLDGROUPS; + + odp.szGroup.a = LPGEN("Popups"); + odp.szTitle.a = LPGEN("Voice Calls"); + odp.pfnDlgProc = PopupsDlgProc; + odp.pszTemplate = MAKEINTRESOURCEA(IDD_POPUPS); + g_plugin.addOptions(wParam, &odp); + + ZeroMemory(&odp, sizeof(odp)); + odp.szGroup.a = LPGEN("Voice Calls"); + odp.szTitle.a = LPGEN("Auto actions"); + odp.pDialog = new CAutoOptsDlg(); + g_plugin.addOptions(wParam, &odp); + } return 0; } -- cgit v1.2.3