summaryrefslogtreecommitdiff
path: root/plugins/HistoryStats/src/dlgconfigure.cpp
diff options
context:
space:
mode:
authorGeorge Hazan <george.hazan@gmail.com>2014-03-04 23:23:45 +0000
committerGeorge Hazan <george.hazan@gmail.com>2014-03-04 23:23:45 +0000
commit15855fa84a09fd1fd486d357c38db0f2bd181e74 (patch)
treec98d1ae74abca41c776522059343eda13a7e0a31 /plugins/HistoryStats/src/dlgconfigure.cpp
parent819f8efabea6b0d7d971f9e6e4b21bbc18838874 (diff)
HistoryStats compiles ok now
git-svn-id: http://svn.miranda-ng.org/main/trunk@8399 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to 'plugins/HistoryStats/src/dlgconfigure.cpp')
-rw-r--r--plugins/HistoryStats/src/dlgconfigure.cpp232
1 files changed, 232 insertions, 0 deletions
diff --git a/plugins/HistoryStats/src/dlgconfigure.cpp b/plugins/HistoryStats/src/dlgconfigure.cpp
new file mode 100644
index 0000000000..5c4ad0b727
--- /dev/null
+++ b/plugins/HistoryStats/src/dlgconfigure.cpp
@@ -0,0 +1,232 @@
+#include "_globals.h"
+#include "dlgconfigure.h"
+
+#include "main.h"
+#include "utils.h"
+#include "dlgoption.h"
+#include "resource.h"
+
+/*
+ * DlgConfigure
+ */
+
+HWND DlgConfigure::m_hCfgWnd = NULL;
+bool DlgConfigure::m_bHookedEvent = false;
+
+INT_PTR CALLBACK DlgConfigure::staticConfigureProc(HWND hDlg, UINT msg, WPARAM wParam, LPARAM lParam)
+{
+ DlgConfigure* pDlg = reinterpret_cast<DlgConfigure*>(GetWindowLong(hDlg, DWLP_USER));
+
+ switch (msg)
+ {
+ case WM_INITDIALOG:
+ pDlg = new DlgConfigure(hDlg);
+ SetWindowLong(hDlg, DWLP_USER, reinterpret_cast<LONG>(pDlg));
+ pDlg->onWMInitDialog();
+ return TRUE;
+
+ case WM_DESTROY:
+ delete pDlg;
+ SetWindowLong(hDlg, DWLP_USER, 0);
+ break;
+
+ case PSM_CHANGED:
+ {
+ EnableWindow(GetDlgItem(hDlg, IDC_APPLY), TRUE);
+ pDlg->m_bChanged = true;
+ }
+ return TRUE;
+
+ case WM_COMMAND:
+ {
+ switch (LOWORD(wParam))
+ {
+ case IDCANCEL:
+ pDlg->onCancel();
+ return TRUE;
+
+ case IDOK:
+ pDlg->onApply();
+ DestroyWindow(hDlg);
+ return TRUE;
+
+ case IDC_APPLY:
+ pDlg->onApply();
+ return TRUE;
+ }
+ }
+ break;
+
+ case WM_WINDOWPOSCHANGED:
+ pDlg->rearrangeControls();
+ return TRUE;
+
+ case WM_GETMINMAXINFO:
+ {
+ static POINT sizeMin = { 0, 0 };
+ MINMAXINFO* pMMI = reinterpret_cast<MINMAXINFO*>(lParam);
+
+ if (sizeMin.x == 0)
+ {
+ RECT rectWin;
+
+ GetWindowRect(hDlg, &rectWin);
+ sizeMin.x = rectWin.right - rectWin.left;
+ sizeMin.y = rectWin.bottom - rectWin.top;
+ }
+
+ pMMI->ptMinTrackSize = sizeMin;
+ }
+ return TRUE;
+ }
+
+ return FALSE;
+}
+
+int DlgConfigure::staticEventPreShutdown(WPARAM wParam, LPARAM lParam)
+{
+ if (IsWindow(m_hCfgWnd))
+ {
+ DestroyWindow(m_hCfgWnd);
+ }
+
+ return 0;
+}
+
+void DlgConfigure::showModal()
+{
+ if (g_bConfigureLock)
+ {
+ MessageBox(
+ 0,
+ i18n(muT("You can't access the stand-alone configuration dialog of HistoryStats as long as the options dialog of Miranda IM is open. Please close the options dialog and try again.\r\n\r\nNote that the options offered by both dialogs are the same.")),
+ i18n(muT("HistoryStats - Warning")),
+ MB_ICONWARNING | MB_OK);
+
+ return;
+ }
+
+ if (IsWindow(m_hCfgWnd))
+ SetForegroundWindow(m_hCfgWnd);
+ else
+ CreateDialog(g_hInst, MAKEINTRESOURCE(IDD_CONFIGURE), NULL, staticConfigureProc);
+}
+
+void DlgConfigure::onWMInitDialog()
+{
+ TranslateDialogDefault(m_hWnd);
+ utils::centerDialog(m_hWnd);
+ SendMessage(m_hWnd, WM_SETICON, ICON_BIG, reinterpret_cast<LPARAM>(LoadIcon(g_hInst, MAKEINTRESOURCE(IDI_HISTORYSTATS))));
+ EnableWindow(GetDlgItem(m_hWnd, IDC_APPLY), FALSE);
+
+ m_hOptWnd = CreateDialogA(g_hInst, MAKEINTRESOURCEA(IDD_OPTIONS), m_hWnd, DlgOption::staticDlgProc);
+
+ ShowWindow(m_hOptWnd, SW_SHOW);
+ SetFocus(m_hOptWnd);
+}
+
+void DlgConfigure::onCancel()
+{
+ PSHNOTIFY pshn;
+
+ pshn.hdr.idFrom = 0;
+ pshn.hdr.code = PSN_RESET;
+ pshn.hdr.hwndFrom = m_hOptWnd;
+ pshn.lParam = 0;
+
+ SendMessage(m_hOptWnd, WM_NOTIFY, 0, reinterpret_cast<LPARAM>(&pshn));
+
+ rearrangeControls();
+
+ DestroyWindow(m_hWnd);
+}
+
+void DlgConfigure::onApply()
+{
+ EnableWindow(GetDlgItem(m_hWnd, IDC_APPLY), FALSE);
+
+ PSHNOTIFY pshn;
+
+ pshn.hdr.idFrom = 0;
+ pshn.hdr.code = PSN_KILLACTIVE;
+ pshn.hdr.hwndFrom = m_hOptWnd;
+ pshn.lParam = 0;
+
+ SendMessage(m_hOptWnd, WM_NOTIFY, 0, reinterpret_cast<LPARAM>(&pshn));
+
+ if (m_bChanged)
+ {
+ m_bChanged = false;
+ pshn.hdr.code = PSN_APPLY;
+
+ SendMessage(m_hOptWnd, WM_NOTIFY, 0, reinterpret_cast<LPARAM>(&pshn));
+ }
+}
+
+void DlgConfigure::rearrangeControls()
+{
+ RECT rClient;
+
+ GetClientRect(m_hWnd, &rClient);
+
+ if (m_nPadY == -1)
+ {
+ RECT rButton = utils::getWindowRect(m_hWnd, IDOK);
+
+ m_nPadY = rClient.bottom - rButton.bottom;
+ m_nOKPadX = rClient.right - rButton.right;
+ m_nCancelPadX = rClient.right - utils::getWindowRect(m_hWnd, IDCANCEL).right;
+ m_nApplyPadX = rClient.right - utils::getWindowRect(m_hWnd, IDC_APPLY).right;
+ }
+
+ RECT rButton;
+
+ rButton = utils::getWindowRect(m_hWnd, IDOK);
+ OffsetRect(&rButton, rClient.right - rButton.right - m_nOKPadX, rClient.bottom - rButton.bottom - m_nPadY);
+ utils::moveWindow(m_hWnd, IDOK, rButton);
+
+ rButton = utils::getWindowRect(m_hWnd, IDCANCEL);
+ OffsetRect(&rButton, rClient.right - rButton.right - m_nCancelPadX, rClient.bottom - rButton.bottom - m_nPadY);
+ utils::moveWindow(m_hWnd, IDCANCEL, rButton);
+
+ rButton = utils::getWindowRect(m_hWnd, IDC_APPLY);
+ OffsetRect(&rButton, rClient.right - rButton.right - m_nApplyPadX, rClient.bottom - rButton.bottom - m_nPadY);
+ utils::moveWindow(m_hWnd, IDC_APPLY, rButton);
+
+ RECT rPage = utils::getWindowRect(m_hWnd, m_hOptWnd);
+
+ rPage.top = m_nPadY;
+ rPage.left = m_nApplyPadX;
+ rPage.right = rClient.right - rClient.left - m_nApplyPadX;
+ rPage.bottom = rButton.top - m_nPadY;
+
+ utils::moveWindow(m_hOptWnd, rPage);
+
+ InvalidateRect(m_hWnd, NULL, TRUE);
+}
+
+DlgConfigure::DlgConfigure(HWND hWnd)
+ : m_hWnd(hWnd), m_bChanged(false), m_hOptWnd(NULL),
+ m_nPadY(-1), m_nOKPadX(0), m_nCancelPadX(0), m_nApplyPadX(0)
+{
+ if (!m_hCfgWnd)
+ {
+ m_hCfgWnd = hWnd;
+
+ if (!m_bHookedEvent)
+ {
+ HookEvent(ME_SYSTEM_PRESHUTDOWN, staticEventPreShutdown);
+ m_bHookedEvent = true;
+ }
+ }
+}
+
+DlgConfigure::~DlgConfigure()
+{
+ DestroyWindow(m_hOptWnd);
+
+ if (m_hWnd == m_hCfgWnd)
+ {
+ m_hCfgWnd = NULL;
+ }
+} \ No newline at end of file