-
Notifications
You must be signed in to change notification settings - Fork 43
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
Add support for displaying C# code samples #487
Comments
I have an idea for this and so would like to tackle this. |
I have a first Spike in this Branch. I've got the code from here. What would be the best way to integrate this? The other repository with the code for the control comes with the MIT licence, so the code can be used. There is no Nuget to embedd that control. Should we create a real control out of it and put it in some UnoExtension /Community toolkit project? Or is it ok to just include it in the Uno Gallery repo? My next idea would be to create a SourceGenerator that automatically extracts the body of an annotated method to a string property that could be bound to from the "CodeHighlightTextBlock". I'm also not sure if this should be included in the gallery itself or if this should be in it's own repo/nuget/project to be more separate from here. I may put both - the CodeHighlightTextBlock and the SourceGenerator for method bodies - into own repos, create a nuget and reference that from the Uno Gallery. What would you suggest? @MartinZikmund @jeromelaban |
Sleeping a night about that topic lead me to the conclusion that both topics deserve an own Nuget. The CodeHighlightTextBox might not be that important to put it into something like the Community toolkit, but it might be interesting for someone else. The same goes for the Source Generator to get the C#-code as a variable. This would clutter the gallery app. |
At this time, to have the best behavior, this would require the use of multiple instances of the Monaco editor, something that is not yet in a production-ready state (unoplatform/uno.monaco-editor-uwp#14). |
That is a nice thing! But also quite heavy for just "showing some code". It is still the plan to use Monaco here? Simply showing code with syntax highlight, selectable and copy-able is already possible with the control from my spike. So, how may I help then? We would still need a simple way to extract the code to show into a ViewModel-Property, right? Shall I concentrate on that or do you also have something in mind for that, too? |
To have some kind of syntax highlighting and selectability, I would say a |
I had a working prototype for the Syntax-highlighting (see above). That could be used and is purely C#-stuff. And we would still need a way to extract the code from the sample-code without doubling it (at least this would be nice). If we want to go that route I would still be happy to contribute. :) |
@TopperDEL your approach uses WebView under the hood correct? |
No, it is a pure C#-implementation. I found a TextBlock-project which renders text with syntax-highligting. See here. |
@TopperDEL @morning4coffe-dev the issue here will be mainly the lack of |
I feel supporting multiple Monaco instances should be the way to go and we'll most probably need it in a refreshed playground... |
I remember there was issue with having multiple monaco editors on wasm, where we cant target an specific editor to set content; it just always target the first. In figma, we got around it by reusing the same editor instance, but at the cost of performance (changing "editor"/tab = reloading the content). The same tech can be used for playground, but it wouldnt work in gallery, due the way it is setup: we cant move the editor around on the visual tree, only resizing. We should probably address this problem first. Syntax highlighting aside, I think there is also the automatic retrieval of actual source, sort of like what ShowMeTheXaml does for .xaml file, but for .cs. |
GitHub Issue (If applicable): #487 <!-- Link to relevant GitHub issue if applicable. All PRs should be associated with an issue (GitHub issue or internal) --> ## PR Type What kind of change does this PR introduce? <!-- Please uncomment one ore more that apply to this PR --> - Build or CI related changes ## What is the new behavior? <!-- Please describe the new behavior after your modifications. --> A Conventional Commits check was added according to our other repositories. ## PR Checklist Please check if your PR fulfills the following requirements: - [ ] Tested on iOS. - [ ] Tested on Wasm. - [ ] Tested on Android. - [ ] Tested on UWP. - [ ] Tested in both **Light** and **Dark** themes. - [x] Associated with an issue (GitHub or internal)
I'm sorry but I still don't get the goal here. I have a partially working solution here in pure C#, that renders C#-code in a control. It is working - we just need to include that control into the gallery app or make a seperate Nuget for that if we do not want to have it clutter up the gallery app. But it is working! To get the actual C#-code that is to show we could leverage a code generator that would embedd the actual code into the control during build so we would always show the exact code there, that is working behind the scenes and was used during the build of the app. It is nice, though, to have a direct link to the code on Github - but that could still be added to my approach. I do not understand why we need that complicated Monado Editor here if we only want to show some C#-code with syntax highlighting. |
I think the easiest could be to use a |
What would you like to be added:
Currently we are able to display XAML code for samples, but not C# code-behind, which is especially relevant for non-UI APIs (but also for some UI APIs).
Why is this needed:
Proper samples
For which Platform:
All
The text was updated successfully, but these errors were encountered: