-
Notifications
You must be signed in to change notification settings - Fork 143
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Synchronized scrolling at diff view #672
Comments
@koppor To me it looks that the code inside Also, the "deleted" code from the left side is written in Java Stream API logic, while the "added" code on the right side is written in more traditional |
@tsantalis Ah - and if there is no relation, then the scroll bars are not synchronized. OK for me... Then you can close this issue. Seems to be an edge case... |
@tsantalis Why was that closed as completed? I was about to open an issue with the same title. I am currently reviewing JabRef/jabref#11245. On GitHub at https://github.com/JabRef/jabref/pull/11245/files, I can just scroll through the diff using my MouseWheel. When using the MouseWheel at RefactoringMiner, it just scrolls one file, not both. Maybe this will be fixed with #703. However, I wanted to restate this. I am still trying to use RefactoringMiner as ReviewTool for GitHub PRs. Should I collect requirements so that RefactoringMinor can be replacement for GitHub PR review or should I stay away? Currently, I think, RefactoringMiner is close, but it could also be like opening a can of worms :) Requirement 1: Mark files as viewed Requirement 2: "Continuous Scrolling" through files. I just want to jump to the next file without having to click back and forth. It is also OK if the next file is opened if I keep scrolling down with the mouse wheel (and the old file closed) Requirement 3: Be able to post comments to lines on the GitHub PR. Requirement 4: Be able to edit the file (a link opening the GitHub edit link is OK) |
Thank you @koppor I will re-open the issue. Thank you for your invaluable feedback. Please understand that we are an academic team with just myself and a few students, and we lack expertise in front-end and UI design. Perhaps a better approach would be to create a browser extension that simply replaces the diff view within the GitHub UI, so that we don't have to re-implement the entire GitHub PR review environment. |
At least you do have students 😅. You can use me for issue refinement for students. I have 10+ years experience with supervising. Excerpt: https://devdocs.jabref.org/teaching.html
I would object here. The hard part is IMHO the diff view you have. Integrating GitHub is just a bit of few lines of REST calls or GraphQL calls. I can reserve time for a MWE if it helps. |
@koppor |
Requirements 1, 3, 4 in #672 (comment) can be done by using the GitHub API and store the entered information directly on GitHub. |
@tsantalis I tried the "Continuous Scrolling" at JabRef/jabref#11476. I like at GitHub that I can use my middle mouse wheel and scroll around the changes. Reason: Typically, the most important (or interesting change) is not the first file, but something "hidden" inbetween. Through scrolling and reading, I try to find that. From there, I navigate around the source. (Yeah, at some point, I will ask to jump between identifiers - similar to Sourcegraph 😅) My wish: If mouse wheel is used and the inner editor cannot scroll, scroll the whole page. This should bring a nicer user experience. Side note: I wish, there was a possibilit to scroll right - I tried with mouse-wheel-right, but did not work: I see that the current implementation prevents to add empty lines left and right to offer a "synchronization" between the code left and right (as GitHub does) However, it is hard to find matches in following diff: Spontaneous answer: Current perception of the feature: All diffs are the same height - and do not adjust to the content. Maybe, this is hard to achieve as it would require major rework of the display -- GitHub adds empty lines to enable a sync between left and right. If there were no scrollbars, the step to have the mousewheel working is surely closer. |
@koppor Just a small side note to clarify the confusion: |
@pouryafard75 I partially understand. Nevertheless, I see that the tool can collapse regions; Thus, the tool does more than just displaying from line 1. A step towards synchronization is for me finding matching pairs. These can be IMHO: same source line - or matched diff (e.g., changed something, e.g., rename) Lets enumerate this as pairs p1, p2, p3, ... - lets use .l and .r for left and right. if p1.l is visible and p1.r is visible and user srolls down so that p1.l is invisible and p1.l is invisible, but p2.l gets visible, then at the right p2.r should be visible, too. The scroll down should be so far that a) p2.r is visible but b) the as least lines as possible are scrolled down at the right side. If possible, one line down at left should lead to a one line down at the right. If in the mode of that lines are matching. Naively, I would really use the first match from the top: If users scrolls one line up at the left, the right also goes up one line. Reason: There is a match found. I am not talking about that it should be possible in 100% of the cases. I think, it can work in 30% to 60% of the cases maybe? Without connecting lines or other helpers to guide me in the view, I cannot review fast. - While writing that, my decision driver gets clear to me: I want to increase my throughput in code reviews. We have in avarage 5 to 10 newcomers each month requesting code revieweing. i would like to give feedback quickly. That means: I want to identify the critical part of a PR fast to be able to give quick feedback. If there is no critical thing, I can review all with patience. If I need to start reveiwing thoroughly from the start, I cannot give timely feedback, because I take more time than my time budget allows me to do. |
@koppor
|
@pouryafard75 @koppor I mean when you are inside the scroll area of diff, the outer scroll does not work. We must expand the individual diffs to the exact space they need, so that there is no inner scrolling. This is top priority issue for making the continuous scrolling useful and a pleasant UI experience. Oliver is right. In this particular PR, the UI experience is not good. |
I am using the tool a bit naively. Not knowing anything of its use by heart. Double click on a change (marked by an arrow) "jumps" to line 65, however, line 60 is highlighted: Expected result on doubleclick somewhere: (I achieved it by a single click left and single click right) I know that a change can range multipel lines; Following "hack" should cover most cases: If ciursor outside of current ast-matched-lines, move cursor to first line of ast. -- This keeps both exiting "selections" (the gray bars) but also moves to the matched element. |
@koppor This way enables the outer scrolling non-stop. By placing the cursor on the left or right side, activates the scrolling within this specific area, and the outer scrolling is getting lost. We will try our best to fix all these issues, so that the user experience is smooth. |
Yeah, I found that. I can also use the scrollbar at the right side. - I was "just" stating, what I would expect as a naive user 😅.
I was adding: If the end of the window is reached, the outer scrolling should take over. -- This will be obsolete if the editor heights will be adjusted.
Thank you so much for continuing working on that part of the tool. I know that UI programming is hard. |
Another nice PR to try out the scrolling (and diff view functionality): langchain4j/langchain4j#1433 |
I tried today with Would still be nice if the heights of the windows could be adjusted somehow. I am aware, this is difficult, because this synchronized scrolling is hard to implement 😅. I just wanted to state that always changing the mouse position for scrolling takes so much energy from me... |
@koppor This one will be very similar to the GitHub commit page. That's a relatively easy PR to review. It has only additions :) |
Hi @koppor The new Single Page View is ready. He have some ideas on how to link code from the left/right side that do not appear next to each other (side by side). For the next weeks, we will be working on some journal paper revisions, so we will take a pause from working on this feature. P.S. Please give it some time (a few seconds), until it fully loads, before you start scrolling. |
@pouryafard75 Case study: org.springframework.web.servlet/src/main/java/org/springframework/web/servlet/mvc/method/annotation/support/HttpEntityMethodProcessor.java -> org.springframework.web.servlet/src/main/java/org/springframework/web/servlet/mvc/method/annotation/support/AbstractMessageConverterMethodProcessor.java org.springframework.web.servlet/src/main/java/org/springframework/web/servlet/mvc/method/annotation/support/RequestResponseBodyMethodProcessor.java -> org.springframework.web.servlet/src/main/java/org/springframework/web/servlet/mvc/method/annotation/support/AbstractMessageConverterMethodProcessor.java Single Page View Screenshot (does not trim the deleted/added code before): Individual Page Screenshot (trims the deleted/added code before): |
Speed up the folding process
The issue was automatically closed from the PR. I re-open it. |
Further fix for tsantalis#672
Further fix for tsantalis#672
Challenging PR to test: JabRef/jabref#11542 Not sure about the collapsing here: |
@koppor The collapsing looks fine to me. Can you elaborate on that? |
I am viewing a diff:
If I scroll on the left, there is no scrolling on the right. I think, the scroll bars should be synchronized. - A more advanced thing could be that the left scroll bar is bound to the right one, but the right one is independent (and thus changes the used offset of the left one).
I think, the current diff is really "too far away" so that any refactorings can be determined... https://github.com/JabRef/jabref/pull/10957/files (I am currently reviewing and I think, there was really too much removed and added without keeping the old functionality)
The text was updated successfully, but these errors were encountered: