-
Notifications
You must be signed in to change notification settings - Fork 30.1k
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
Explore cell level commenting in notebooks #144850
Comments
Current prototype:
Screen.Recording.2022-03-17.at.2.32.23.PM.mov |
Hi, thanks for building basic comment support into the notebook editor with #145090. I found it a bit tricky to work with that it expect comments to be attached to the cell URI, not the file URI. The issue with that is that the cell URI is dynamically created during deserializing (from the file URI changing the scheme and adding a cell fragment which is basically an encoded increasing number), but VSCode also has a comments panel, where the comment should ideally be shown even before you open the file. At that point the cell URI is unknown. I was wondering how you deal with that, and tried to get Github Pull Request comments to show up in the NotebookEditor for ipynb files, which does not seem to work: They are only shown when I reopen the ipynb file in a TextEditor. I have a workaround, which starts creating the comments with the file URI, and the line number in the raw JSON ipynb file, and then upon opening the notebook editor, recreates the CommentThread with the cell URI (and cell-relative line number) as it becomes known. I need to recreate because the URI of a CommentThread is actually Instead, I wonder if we could not leave CommentThreads on the file URI, and when we fetch the comments for a notebook in getNotebookComments, derive the appropriate cell id and cell-line-number from the raw file URI and line number. This would require some sort of source map between the raw file numbers and the structure of the notebook, and as VSCode hands off deserialization to extensible NotebookSerializers, that API would also need to allow providing a source map. As an example,
If a NotebookSerializer fills that, then it is used to map any file URI comments for notebook files to the corresponding cell locations in the notebook editor. The inverse transformation may be needed when creating a new comment on a cell. One issue is that I believe right now cells do have a stable ID (beyond this increasing integer which is ephemeral) - maybe that could be added for this purpose (or we would have to make the assumption that we can reference the deserialized cells by their index in the serialized source). Another issue might be comments on cells that were not in the serialized source. We can probably work through these issues. What do you think about this proposal? Is there some simpler approach that I am overlooking? I would be happy to contribute the changes, but would like to align on the design direction first. Cheers |
We will explore how to bring the commenting experience from the monaco editor to the notebook land.
CommentController/CommentThread
for notebook rangesCommentRangeProvider
should also support notebook document if it's still neededReactionHandler
has no dependencies on text document range, so it doesn't need to be updatedCommentThreadWidget
in the core is a monaco editorViewZone
instance. It is tied toViewZone
's lifecyle and event handers. We want to extract it to a common widget and share it with notebook editor.CommentThreadWidget
can be rendered as aCellPart
but it might have performance issue.ViewZone
s in monaco editor doesn't do virtualization so it's not affected by the slow/costly creation.ViewZone
layer in Monaco Editor. TheCommentThreadWidget
can be absolutely positioned in this layer. The comments then will not be treated as parts of aCell
.The text was updated successfully, but these errors were encountered: