-
-
Notifications
You must be signed in to change notification settings - Fork 174
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
Line Annotations #51
Line Annotations #51
Conversation
Yes! I'd love to have some kind of line annotations. They are much better than notes. I don't have anwsers for your questions yet. I'm focusing on another project right now. I'll come back to code-surfer soon (in a few weeks) 'cause I need to write a talk and I want to rewrite a big part of this project to support new features. |
Great, glad that the feature is also valuable for others!
Sure, I've added a TODO in the description. I'll do this along with any feedback that you have in a few weeks :) |
I've also changed the |
Did you have a chance to put some more thought into this? |
Hi @karlhorky , I'm currently rewriting code surfer from scratch to support new things. Line annotations is one of those things I want to support. I'm keeping this PR open as a reference. |
Ok, if you're reimplementing this feature, I may be able to be of assistance. Maybe it would make sense to make it more general and easier to work with. For example, general annotations for anything? Maybe with a default style for the "pointer"/"tooltip" element? |
Hi @pomber ! Now that v3 has dropped, do you have any insights into how such a feature could be implemented there? Would really like to do this to be able to annotate my code like in the examples above :) |
I want to use something like annotations for blogging too. One approach I want to try is to provide a But I don't have the time now, it would have to wait... |
Ok, so there's no way to do this at the moment, even with a more hacky solution? I guess I'll have to wait to upgrade then... Or find some workaround... |
For now, you could try to write your own version of this component and hardcode the annotations there for each slide. But it may be too hacky... |
Ok, will take a look, maybe I can get something working. Thanks! |
Hey @pomber, I didn't get a chance to try this out yet... Any news from your side on this feature? |
Hi. Not really. I'm focusing more on this other project, which eventually should replace the core of code surfer and be more flexible. |
Ok thanks. I guess probably no ETA for Code Hike?
Maybe time to try to upgrade one of my decks to |
Ah just trying this out - unless I'm missing something I guess the new Code Surfer steps API is much less flexible :( Maybe I move off of Code Surfer completely and try to implement my own thing using |
That may be the best alternative if you need something soon |
Ok, I've opened up a followup to this in #115, maybe we can continue the discussion over there... |
Hi! First of all, thanks for this great project! It's super useful.
I'm creating teaching materials (course material) with this tool, and I would like to annotate certain parts of the source code with arrows, indicators, labels and other diagram elements that are not in monospace font (see examples below) - some similarities to LaTeX brackets / parentheses / braces. I tried to use the current APIs, but I didn't get very far.
I ended up creating an MVP solution (described below) and I wanted to get feedback on it :)
TODO
Ideal Examples
Current MVP Solution
In order to do the very minimum of implementation work with the largest impact, I have created an MVP for only line annotations that allows for strings and React components to be passed via a new property called
lineAnnotations
in the step object, which is an object mapping lines to their annotation content.The MVP is currently published under
@upleveled/[email protected]
(depends on@upleveled/[email protected]
).To try it out:
It allows for things like this:
via this code:
What are your opinions of this API?
More specifically:
Scroller.Element
at all?step-parser.js
test file?