Commit 3c74b02
authored
[CAP-7450] Implement paginated infinite scroll on CLI logs viewer (#243)
* Move log limit constant into shared package
Might be overkill, but this will protect us against documentation inconsistency if we decide to change this value in the backend.
* [CAP-7450] Implement paginated infinite scroll on CLI logs viewer
Implements automatic pagination for the logs viewer that fetches additional logs when users scroll to the boundaries of the fetched log data. The initial log request continues to respect the `limit` flag, but subsequent requests (triggered by scrolling) are auto-paginated with a 1000-log limit. Subsequent requests are also 'silent' and do not display the loading spinner.
Logs always display oldest to newest regardless of "direction", consistent with the existing implementation. ("Direction" only affects which end of the fetched set appears first in the viewport.)
* [CAP-7450] Support scrolling up immediately after initial log load
Existing logic only fetches logs when the viewport has shifted to a boundary of the fetched set. This is valuable because it prevents us from fetching older logs until the user requests it; however it also prevents the user from immediately scrolling up after the initial log fetch because the viewport has not shifted. This commit manually detects a scroll up key binding when the viewport hasn't changed.
The corresponding check will never come into play in the "down" direction unless the user specifies `--limit=1`, at which point they clearly don't want more logs anyway so we shan't provide them.
* Actually allow pagination requests to fetch 1000 logs at a time1 parent 092c6a9 commit 3c74b02
File tree
6 files changed
+414
-9
lines changed- cmd
- pkg
- logs
- tui
- views
6 files changed
+414
-9
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
11 | 11 | | |
12 | 12 | | |
13 | 13 | | |
| 14 | + | |
14 | 15 | | |
15 | 16 | | |
16 | 17 | | |
| |||
74 | 75 | | |
75 | 76 | | |
76 | 77 | | |
77 | | - | |
| 78 | + | |
78 | 79 | | |
79 | 80 | | |
80 | 81 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
28 | 28 | | |
29 | 29 | | |
30 | 30 | | |
| 31 | + | |
31 | 32 | | |
32 | 33 | | |
33 | 34 | | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
34 | 45 | | |
35 | 46 | | |
36 | 47 | | |
| |||
39 | 50 | | |
40 | 51 | | |
41 | 52 | | |
42 | | - | |
43 | | - | |
44 | | - | |
45 | | - | |
46 | | - | |
47 | | - | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
48 | 60 | | |
49 | 61 | | |
50 | 62 | | |
51 | 63 | | |
52 | 64 | | |
53 | 65 | | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
54 | 75 | | |
55 | 76 | | |
56 | 77 | | |
| |||
97 | 118 | | |
98 | 119 | | |
99 | 120 | | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
100 | 137 | | |
101 | 138 | | |
102 | 139 | | |
103 | 140 | | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
| 151 | + | |
| 152 | + | |
| 153 | + | |
| 154 | + | |
| 155 | + | |
| 156 | + | |
| 157 | + | |
| 158 | + | |
| 159 | + | |
| 160 | + | |
| 161 | + | |
| 162 | + | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
104 | 171 | | |
105 | 172 | | |
106 | 173 | | |
107 | | - | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
| 177 | + | |
| 178 | + | |
| 179 | + | |
| 180 | + | |
| 181 | + | |
| 182 | + | |
| 183 | + | |
| 184 | + | |
| 185 | + | |
| 186 | + | |
| 187 | + | |
| 188 | + | |
| 189 | + | |
| 190 | + | |
| 191 | + | |
| 192 | + | |
| 193 | + | |
| 194 | + | |
| 195 | + | |
| 196 | + | |
| 197 | + | |
| 198 | + | |
108 | 199 | | |
109 | 200 | | |
| 201 | + | |
110 | 202 | | |
111 | 203 | | |
112 | 204 | | |
| |||
0 commit comments