diff options
author | George Hazan <ghazan@miranda.im> | 2020-04-29 18:59:21 +0300 |
---|---|---|
committer | George Hazan <ghazan@miranda.im> | 2020-04-29 18:59:21 +0300 |
commit | d781cfdb76e0e81e0990208514e614d1b785d803 (patch) | |
tree | 36c0857fb8645307736c7039654f5e34e6ee634d /plugins/NewStory/src | |
parent | 314930f98aac1dd2c482ff3b79d4810142dc25f9 (diff) |
fixes #2363 (NewStory: add ability to clear history for specified contact)
Diffstat (limited to 'plugins/NewStory/src')
-rw-r--r-- | plugins/NewStory/src/history.cpp | 39 | ||||
-rw-r--r-- | plugins/NewStory/src/history_array.h | 5 | ||||
-rw-r--r-- | plugins/NewStory/src/history_control.cpp | 89 | ||||
-rw-r--r-- | plugins/NewStory/src/history_control.h | 1 | ||||
-rw-r--r-- | plugins/NewStory/src/resource.h | 1 |
5 files changed, 84 insertions, 51 deletions
diff --git a/plugins/NewStory/src/history.cpp b/plugins/NewStory/src/history.cpp index c01e150e54..eb29b2e624 100644 --- a/plugins/NewStory/src/history.cpp +++ b/plugins/NewStory/src/history.cpp @@ -72,12 +72,12 @@ enum { TBTN_USERINFO, TBTN_USERMENU, TBTN_MESSAGE, TBTN_SEARCH, TBTN_FILTER, TBTN_DATEPOPUP, - TBTN_COPY, TBTN_EXPORT, + TBTN_COPY, TBTN_DELETE, TBTN_EXPORT, TBTN_LOGOPTIONS, TBTN_COUNT }; -int tbtnSpacing[TBTN_COUNT] = { 0, 0, TBTN_SPACER, 0, 0, TBTN_SPACER, 0, -1, 0 }; +int tbtnSpacing[TBTN_COUNT] = { 0, 0, TBTN_SPACER, 0, 0, TBTN_SPACER, 0, 0, -1, 0 }; struct InfoBarEvents { @@ -198,7 +198,7 @@ class CHistoryDlg : public CDlgBase int w = rc.right - rc.left; int h = rc.bottom - rc.top; - HDWP hDwp = BeginDeferWindowPos(50); + HDWP hDwp = BeginDeferWindowPos(51); // toolbar int hToolBar = TBTN_SIZE + WND_SPACING; @@ -313,10 +313,20 @@ class CHistoryDlg : public CDlgBase EndDeferWindowPos(hDwp); } + void UpdateTitle() + { + if (m_hContact && m_hContact != INVALID_CONTACT_ID) + SetWindowText(m_hwnd, ptrW(TplFormatString(TPL_TITLE, m_hContact, 0))); + else if (m_hContact == INVALID_CONTACT_ID) + SetWindowText(m_hwnd, TranslateT("History search results")); + else + SetWindowText(m_hwnd, TranslateT("System history")); + } + CCtrlBase m_histControl; CCtrlEdit edtSearchText; CCtrlMButton btnUserInfo, btnSendMsg, btnUserMenu, btnCopy, btnOptions, btnFilter; - CCtrlMButton btnCalendar, btnSearch, btnExport, btnFindNext, btnFindPrev; + CCtrlMButton btnCalendar, btnSearch, btnExport, btnFindNext, btnFindPrev, btnDelete; CCtrlTreeView m_timeTree; public: @@ -328,6 +338,7 @@ public: edtSearchText(this, IDC_SEARCHTEXT), btnCopy(this, IDC_COPY, g_plugin.getIcon(ICO_COPY), LPGEN("Copy")), btnExport(this, IDC_EXPORT, g_plugin.getIcon(ICO_EXPORT), LPGEN("Export...")), + btnDelete(this, IDC_DELETE, Skin_LoadIcon(SKINICON_OTHER_DELETE), LPGEN("Delete...")), btnFilter(this, IDC_FILTER, g_plugin.getIcon(ICO_FILTER), LPGEN("Filter")), btnSearch(this, IDC_SEARCH, g_plugin.getIcon(ICO_SEARCH), LPGEN("Search...")), btnOptions(this, IDC_LOGOPTIONS, g_plugin.getIcon(ICO_OPTIONS), LPGEN("Options")), @@ -344,6 +355,7 @@ public: btnCopy.OnClick = Callback(this, &CHistoryDlg::onClick_Copy); btnExport.OnClick = Callback(this, &CHistoryDlg::onClick_Export); + btnDelete.OnClick = Callback(this, &CHistoryDlg::onClick_Delete); btnFilter.OnClick = Callback(this, &CHistoryDlg::onClick_Filter); btnSearch.OnClick = Callback(this, &CHistoryDlg::onClick_Search); btnOptions.OnClick = Callback(this, &CHistoryDlg::onClick_Options); @@ -389,6 +401,7 @@ public: m_hwndBtnToolbar[TBTN_SEARCH] = btnSearch.GetHwnd(); m_hwndBtnToolbar[TBTN_COPY] = btnCopy.GetHwnd(); m_hwndBtnToolbar[TBTN_EXPORT] = btnExport.GetHwnd(); + m_hwndBtnToolbar[TBTN_DELETE] = btnDelete.GetHwnd(); m_hwndBtnToolbar[TBTN_LOGOPTIONS] = btnOptions.GetHwnd(); m_hwndBtnToolbar[TBTN_FILTER] = btnFilter.GetHwnd(); m_hwndBtnToolbar[TBTN_DATEPOPUP] = btnCalendar.GetHwnd(); @@ -464,17 +477,7 @@ public: WindowList_Add(hNewstoryWindows, m_hwnd, m_hContact); - if (m_hContact && (m_hContact != INVALID_CONTACT_ID)) { - wchar_t *title = TplFormatString(TPL_TITLE, m_hContact, 0); - SetWindowText(m_hwnd, title); - mir_free(title); - } - else { - if (m_hContact == INVALID_CONTACT_ID) - SetWindowText(m_hwnd, TranslateT("History search results")); - else - SetWindowText(m_hwnd, TranslateT("System history")); - } + UpdateTitle(); ADDEVENTS tmp = { m_hContact, 0, -1 }; SendMessage(m_histControl.GetHwnd(), NSM_ADDEVENTS, WPARAM(&tmp), 0); @@ -532,6 +535,12 @@ public: m_histControl.SendMsg(NSM_COPY, 0, 0); } + void onClick_Delete(CCtrlButton *) + { + m_histControl.SendMsg(NSM_DELETE, 0, 0); + UpdateTitle(); + } + void onClick_Export(CCtrlButton *) { wchar_t FileName[MAX_PATH]; diff --git a/plugins/NewStory/src/history_array.h b/plugins/NewStory/src/history_array.h index ece447676d..50e6fb1c97 100644 --- a/plugins/NewStory/src/history_array.h +++ b/plugins/NewStory/src/history_array.h @@ -135,6 +135,11 @@ public: void addChatEvent(SESSION_INFO *si, LOGINFO *pEvent); void clear(); int getCount() const; + void reset() + { + clear(); + pages.insert(new ItemBlock()); + } // bool preloadEvents(int count = 10); diff --git a/plugins/NewStory/src/history_control.cpp b/plugins/NewStory/src/history_control.cpp index 5a7e2c8128..a7b6327a96 100644 --- a/plugins/NewStory/src/history_control.cpp +++ b/plugins/NewStory/src/history_control.cpp @@ -2,6 +2,8 @@ HANDLE htuLog = 0; +static wchar_t wszDelete[] = LPGENW("Are you sure to remove all events from history?"); + ///////////////////////////////////////////////////////////////////////// // Control utilities, types and constants @@ -480,13 +482,14 @@ LRESULT CALLBACK NewstoryListWndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM { int start = min(data->items.getCount() - 1, max(0, wParam)); int end = min(data->items.getCount() - 1, max(0, lParam)); - if (start > end) { - start ^= end; - end ^= start; - start ^= end; + if (start > end) + std::swap(start, end); + + for (int i = start; i <= end; ++i) { + auto *p = data->items.get(i, ItemData::ELM_NOTHING); + p->flags |= HIF_SELECTED; } - for (int i = start; i <= end; ++i) - data->items.get(i, ItemData::ELM_NOTHING)->flags |= HIF_SELECTED; + InvalidateRect(hwnd, 0, FALSE); return 0; } @@ -495,19 +498,14 @@ LRESULT CALLBACK NewstoryListWndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM { int start = min(data->items.getCount() - 1, max(0, wParam)); int end = min(data->items.getCount() - 1, max(0, lParam)); - if (start > end) { - start ^= end; - end ^= start; - start ^= end; - } + if (start > end) + std::swap(start, end); + for (int i = start; i <= end; ++i) { - if (data->items.get(i, ItemData::ELM_NOTHING)->flags & HIF_SELECTED) { - data->items.get(i, ItemData::ELM_NOTHING)->flags &= ~HIF_SELECTED; - } - else { - data->items.get(i, ItemData::ELM_NOTHING)->flags |= HIF_SELECTED; - } + auto *p = data->items.get(i, ItemData::ELM_NOTHING); + p->flags ^= HIF_SELECTED; } + InvalidateRect(hwnd, 0, FALSE); return 0; } @@ -516,20 +514,18 @@ LRESULT CALLBACK NewstoryListWndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM { int start = min(data->items.getCount() - 1, max(0, wParam)); int end = min(data->items.getCount() - 1, max(0, lParam)); - if (start > end) { - start ^= end; - end ^= start; - start ^= end; - } + if (start > end) + std::swap(start, end); + int count = data->items.getCount(); for (int i = 0; i < count; ++i) { - if ((i >= start) && (i <= end)) { - data->items.get(i, ItemData::ELM_NOTHING)->flags |= HIF_SELECTED; - } - else { - data->items.get(i, ItemData::ELM_NOTHING)->flags &= ~((DWORD)HIF_SELECTED); - } + auto *p = data->items.get(i, ItemData::ELM_NOTHING); + if ((i >= start) && (i <= end)) + p->flags |= HIF_SELECTED; + else + p->flags &= ~((DWORD)HIF_SELECTED); } + InvalidateRect(hwnd, 0, FALSE); return 0; } @@ -543,8 +539,11 @@ LRESULT CALLBACK NewstoryListWndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM end ^= start; start ^= end; } - for (int i = start; i <= end; ++i) - data->items.get(i, ItemData::ELM_NOTHING)->flags &= ~((DWORD)HIF_SELECTED); + for (int i = start; i <= end; ++i) { + auto *p = data->items.get(i, ItemData::ELM_NOTHING); + p->flags &= ~((DWORD)HIF_SELECTED); + } + InvalidateRect(hwnd, 0, FALSE); return 0; } @@ -558,8 +557,8 @@ LRESULT CALLBACK NewstoryListWndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM RECT rc; GetClientRect(hwnd, &rc); int height = rc.bottom - rc.top; - DWORD count = data->items.getCount(); - DWORD current = data->scrollTopItem; + int count = data->items.getCount(); + int current = data->scrollTopItem; int top = data->scrollTopPixel; int bottom = top + LayoutItem(hwnd, &data->items, current); while (top <= height) { @@ -607,14 +606,14 @@ LRESULT CALLBACK NewstoryListWndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM { int eventCount = data->items.getCount(); for (int i = 0; i < eventCount; i++) { - auto *item = data->items.get(i, ItemData::ELM_NOTHING); - if (item->dbe.timestamp >= wParam) { + auto *p = data->items.get(i, ItemData::ELM_NOTHING); + if (p->dbe.timestamp >= wParam) { SendMessage(hwnd, NSM_SELECTITEMS2, i, i); SendMessage(hwnd, NSM_SETCARET, i, TRUE); break; } - if (i == eventCount - 1) - { + + if (i == eventCount - 1) { SendMessage(hwnd, NSM_SELECTITEMS2, i, i); SendMessage(hwnd, NSM_SETCARET, i, TRUE); } @@ -626,6 +625,24 @@ LRESULT CALLBACK NewstoryListWndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM SendMessage(hwnd, NSM_SETCARET, data->items.getCount() - 1, 1); break; + case NSM_DELETE: + if (IDYES == MessageBoxW(hwnd, TranslateW(wszDelete), _T(MODULETITLE), MB_YESNOCANCEL | MB_ICONQUESTION)) { + db_set_safety_mode(false); + + int eventCount = data->items.getCount(); + for (int i = eventCount - 1; i >= 0; i--) { + auto *p = data->items.get(i, ItemData::ELM_NOTHING); + if (p->hEvent && p->hContact) + db_event_delete(p->hEvent); + } + db_set_safety_mode(true); + + data->items.reset(); + + InvalidateRect(hwnd, 0, FALSE); + } + break; + case NSM_COPY: { CMStringW res; diff --git a/plugins/NewStory/src/history_control.h b/plugins/NewStory/src/history_control.h index 0d0650aaaa..0483ac9112 100644 --- a/plugins/NewStory/src/history_control.h +++ b/plugins/NewStory/src/history_control.h @@ -63,6 +63,7 @@ enum // NSM_COPY, + NSM_DELETE, NSM_EXPORT, // diff --git a/plugins/NewStory/src/resource.h b/plugins/NewStory/src/resource.h index f52b7eaf74..09f898d558 100644 --- a/plugins/NewStory/src/resource.h +++ b/plugins/NewStory/src/resource.h @@ -62,6 +62,7 @@ #define IDC_ICO_URLS_IN 1031 #define IDC_ICO_URLS_OUT 1032 #define IDC_PREVIEW 1033 +#define IDC_DELETE 1034 #define IDC_TIMETREE 1035 #define IDC_PROGRESS1 1037 //!!! #define IDC_COMBO1 1038 //!!! |