summaryrefslogtreecommitdiff
path: root/plugins/HistoryStats/src/column_events.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/column_events.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/column_events.cpp')
-rw-r--r--plugins/HistoryStats/src/column_events.cpp92
1 files changed, 92 insertions, 0 deletions
diff --git a/plugins/HistoryStats/src/column_events.cpp b/plugins/HistoryStats/src/column_events.cpp
new file mode 100644
index 0000000000..2186f8bb91
--- /dev/null
+++ b/plugins/HistoryStats/src/column_events.cpp
@@ -0,0 +1,92 @@
+#include "_globals.h"
+#include "column_events.h"
+
+/*
+ * ColEvents
+ */
+
+ColEvents::ColEvents()
+ : m_nSource(5), m_hSource(NULL)
+{
+}
+
+void ColEvents::impl_copyConfig(const Column* pSource)
+{
+ const ColEvents& src = *reinterpret_cast<const ColEvents*>(pSource);
+
+ m_nSource = src.m_nSource;
+}
+
+void ColEvents::impl_configRead(const SettingsTree& settings)
+{
+ m_nSource = settings.readIntRanged(con::KeySource, 5, 0, 5);
+}
+
+void ColEvents::impl_configWrite(SettingsTree& settings) const
+{
+ settings.writeInt(con::KeySource, m_nSource);
+}
+
+void ColEvents::impl_configToUI(OptionsCtrl& Opt, OptionsCtrl::Item hGroup)
+{
+ m_hSource = Opt.insertCombo(hGroup, i18n(muT("Events to count")));
+
+ static const mu_text* sourceTexts[] = {
+ I18N(muT("URLs (incoming)")),
+ I18N(muT("URLs (outgoing)")),
+ I18N(muT("URLs (all)")),
+ I18N(muT("Files (incoming)")),
+ I18N(muT("Files (outgoing)")),
+ I18N(muT("Files (all)")),
+ };
+
+ array_each_(i, sourceTexts)
+ {
+ Opt.addComboItem(m_hSource, i18n(sourceTexts[i]));
+ }
+
+ Opt.setComboSelected(m_hSource, m_nSource);
+}
+
+void ColEvents::impl_configFromUI(OptionsCtrl& Opt)
+{
+ m_nSource = Opt.getComboSelected(m_hSource);
+}
+
+void ColEvents::impl_outputRenderHeader(ext::ostream& tos, int row, int rowSpan) const
+{
+ static const mu_text* szShortDesc[] = {
+ I18N(muT("URLs")),
+ I18N(muT("Files")),
+ };
+
+ static const mu_text* szSourceDesc[] = {
+ I18N(muT("Incoming URLs")),
+ I18N(muT("Outgoing URLs")),
+ I18N(muT("URLs")),
+ I18N(muT("Incoming files")),
+ I18N(muT("Outgoing files")),
+ I18N(muT("Files")),
+ };
+
+ if (row == 1)
+ {
+ writeRowspanTD(tos, getCustomTitle(i18n(szShortDesc[m_nSource / 3]), i18n(szSourceDesc[m_nSource])), row, 1, rowSpan);
+ }
+}
+
+void ColEvents::impl_outputRenderRow(ext::ostream& tos, const Contact& contact, DisplayType display)
+{
+ static int (Contact::*getData[6])() const = {
+ &Contact::getInUrls,
+ &Contact::getOutUrls,
+ &Contact::getTotalUrls,
+ &Contact::getInFiles,
+ &Contact::getOutFiles,
+ &Contact::getTotalFiles,
+ };
+
+ tos << muT("<td class=\"num\">")
+ << utils::intToGrouped((contact.*getData[m_nSource])())
+ << muT("</td>") << ext::endl;
+}