summaryrefslogtreecommitdiff
path: root/plugins/NewStory/src/history_control.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/NewStory/src/history_control.cpp')
-rw-r--r--plugins/NewStory/src/history_control.cpp124
1 files changed, 78 insertions, 46 deletions
diff --git a/plugins/NewStory/src/history_control.cpp b/plugins/NewStory/src/history_control.cpp
index 7c391f9fde..22e515eb3f 100644
--- a/plugins/NewStory/src/history_control.cpp
+++ b/plugins/NewStory/src/history_control.cpp
@@ -26,12 +26,14 @@ struct NewstoryListData : public MZeroedObject
int scrollTopItem; // topmost item
int scrollTopPixel; // y coord of topmost item, this should be negative or zero
int caret;
+ int selStart = -1;
int cachedWindowHeight;
int cachedMaxTopItem; // the largest ID of top item to avoid empty space
int cachedMaxTopPixel;
RECT rcLastPaint;
- bool repaint;
+
+ bool bWasShift;
HWND hwnd;
HWND hwndEditBox;
@@ -359,6 +361,13 @@ struct NewstoryListData : public MZeroedObject
FixScrollPosition();
}
+
+ void SetPos(int pos)
+ {
+ caret = pos;
+ SendMessage(hwnd, NSM_SELECTITEMS2, (selStart == -1) ? pos : selStart, pos);
+ SendMessage(hwnd, NSM_SETCARET, pos, TRUE);
+ }
};
// Edit box
@@ -407,11 +416,11 @@ LRESULT CALLBACK NewstoryListWndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM
SetWindowLongPtr(hwnd, 0, (LONG_PTR)data);
if (!g_plugin.bOptVScroll)
SetWindowLong(hwnd, GWL_STYLE, GetWindowLong(hwnd, GWL_STYLE) & ~WS_VSCROLL);
- else
+ else
data->RecalcScrollBar();
break;
- // History list control messages
+ // History list control messages
case NSM_ADDEVENTS:
if (auto *p = (ADDEVENTS *)wParam)
data->items.addEvent(p->hContact, p->hFirstEVent, p->eventCount);
@@ -421,7 +430,7 @@ LRESULT CALLBACK NewstoryListWndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM
break;
case NSM_ADDCHATEVENT:
- data->items.addChatEvent((SESSION_INFO *)wParam, (LOGINFO*)lParam);
+ data->items.addChatEvent((SESSION_INFO *)wParam, (LOGINFO *)lParam);
data->redrawTimer.Stop();
data->redrawTimer.Start(100);
@@ -451,7 +460,7 @@ LRESULT CALLBACK NewstoryListWndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM
auto *p = data->items.get(i, false);
p->bSelected = true;
}
-
+
InvalidateRect(hwnd, 0, FALSE);
return 0;
}
@@ -467,7 +476,7 @@ LRESULT CALLBACK NewstoryListWndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM
auto *p = data->items.get(i, false);
p->bSelected = !p->bSelected;
}
-
+
InvalidateRect(hwnd, 0, FALSE);
return 0;
}
@@ -482,12 +491,12 @@ LRESULT CALLBACK NewstoryListWndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM
int count = data->items.getCount();
for (int i = 0; i < count; ++i) {
auto *p = data->items.get(i, false);
- if ((i >= start) && (i <= end))
+ if ((i >= start) && (i <= end))
p->bSelected = true;
else
p->bSelected = false;
}
-
+
InvalidateRect(hwnd, 0, FALSE);
return 0;
}
@@ -505,7 +514,7 @@ LRESULT CALLBACK NewstoryListWndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM
auto *p = data->items.get(i, false);
p->bSelected = false;
}
-
+
InvalidateRect(hwnd, 0, FALSE);
return 0;
}
@@ -690,48 +699,71 @@ LRESULT CALLBACK NewstoryListWndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM
return DLGC_WANTMESSAGE;
case WM_KEYDOWN:
- switch (wParam) {
- case VK_UP:
- SendMessage(hwnd, NSM_SELECTITEMS2, data->caret - 1, data->caret - 1);
- SendMessage(hwnd, NSM_SETCARET, data->caret - 1, TRUE);
- break;
+ {
+ bool isShift = (GetKeyState(VK_SHIFT) & 0x80) != 0;
+ bool isCtrl = (GetKeyState(VK_CONTROL) & 0x80) != 0;
+
+ if (!data->bWasShift && isShift)
+ data->selStart = data->caret;
+ else if (data->bWasShift && !isShift)
+ data->selStart = -1;
+ data->bWasShift = isShift;
+
+ switch (wParam) {
+ case VK_UP:
+ if (data->caret > 0)
+ data->SetPos(data->caret - 1);
+ break;
- case VK_DOWN:
- SendMessage(hwnd, NSM_SELECTITEMS2, data->caret + 1, data->caret + 1);
- SendMessage(hwnd, NSM_SETCARET, data->caret + 1, TRUE);
- break;
+ case VK_DOWN:
+ if (data->caret < data->items.getCount()-1)
+ data->SetPos(data->caret + 1);
+ break;
- case VK_PRIOR:
- break;
+ case VK_PRIOR:
+ if (!isCtrl && data->caret > 10)
+ data->SetPos(data->caret - 10);
+ else
+ data->SetPos(0);
+ break;
- case VK_NEXT:
- break;
+ case VK_NEXT:
+ if (int count = data->items.getCount()) {
+ if (!isCtrl && data->caret + 10 < count-1)
+ data->SetPos(data->caret + 10);
+ else
+ data->SetPos(count - 1);
+ }
+ break;
- case VK_HOME:
- break;
+ case VK_HOME:
+ data->SetPos(0);
+ break;
- case VK_END:
- break;
+ case VK_END:
+ if (int count = data->items.getCount())
+ data->SetPos(count - 1);
+ break;
- case VK_F2:
- data->BeginEditItem(data->caret);
- break;
- }
- break;
+ case VK_F2:
+ data->BeginEditItem(data->caret);
+ break;
- case WM_SYSCHAR:
- case WM_CHAR:
- if (wParam == 27) {
- if (data->hwndEditBox)
- data->EndEditItem();
- }
- else {
- char ch = MapVirtualKey((lParam >> 16) & 0xff, 1);
- if (((ch == 'C') || (ch == VK_INSERT)) && (GetKeyState(VK_CONTROL) & 0x80)) {
- PostMessage(hwnd, NSM_COPY, 0, 0);
- }
- else if ((ch == 'A') && (GetKeyState(VK_CONTROL) & 0x80)) {
- SendMessage(hwnd, NSM_SELECTITEMS, 0, data->items.getCount());
+ case VK_ESCAPE:
+ if (data->hwndEditBox)
+ data->EndEditItem();
+ break;
+
+ case VK_INSERT:
+ case 'C':
+ if (isCtrl)
+ PostMessage(hwnd, NSM_COPY, 0, 0);
+ break;
+
+ case 'A':
+ if (isCtrl)
+ SendMessage(hwnd, NSM_SELECTITEMS, 0, data->items.getCount());
+ break;
}
}
break;
@@ -806,10 +838,10 @@ LRESULT CALLBACK NewstoryListWndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM
switch (LOWORD(wParam)) {
case SB_LINEUP:
- data->ScrollListBy(0, 10);
+ data->ScrollListBy(0, -10);
break;
case SB_LINEDOWN:
- data->ScrollListBy(0, -10);
+ data->ScrollListBy(0, 10);
break;
case SB_PAGEUP:
data->ScrollListBy(-10, 0);