-
-
Notifications
You must be signed in to change notification settings - Fork 130
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
DocsUI: Messages Object output #618
Comments
RFC: Proposal for new UX for Payload documentation outputhttps://www.loom.com/share/dba7481f296046629b30995628b924e3 Here is a new idea I have that could improve the experience of the Payload component. My inspiration came from browser developer tools where you can toggle all levels of an object with ease and see everything you need in one line. Some more features that we should add: |
Yeah, it looks very good, however have in mind that metadata of single property can be very complex. At the moment you render type, name, format and description. We can have also constraints like
Yeah, we should have that implemented, button to collapse only one level and all levels. I added suggestion to current design in this PR #620 |
@magicmatatjahu Thanks for that feedback! @fmvilas explained the problems with showing the constraints of each property to me during our 1:1 call and how that could become confusing on one line. He also mentioned that we should think about the fact that Going to take that information and come up with some other solutions that might work. Thanks! 😄 |
Updated Payload Output DesignHi here is a video explaining the new design iteration for the |
I love the idea for long descriptions ❤️ |
Hey all! 👋 I have been working on an update for this issue, and wanted to first offer it in video form if that suits you: https://www.loom.com/share/6d24178eb4fc43b49c30f4696f2761ae Went back to the drawing boardAfter presenting the previous idea during the community meeting livestream, I received some great feedback that led me to the conclusion that we needed to head back to the drawing board and address some concerns that were mentioned:
Well, before I felt like I could dive headfirst into ideation on these two issues, I felt like I had to do some background research to better understand JSON schema and the different complexities within. Along this journey, I started brainstorming in a FigJam file and jotted down some of the "bread and butter" components that is needed for your JSON schema. Click here to open the FigJam -> https://www.figma.com/file/j6UgI3CC6bmzv6NRpaNEtF/JSON-Schema-Brainstorm?node-id=0%3A1 After defining the 🍞 & 🧈, I felt like I could once again start coming up with a layout that would make sense to build off of. From this idea, I began to craft wireframes at a bit higher of a level but not focused so much on UI to see if I can start hammering out an established experience. And here is this experience put to the test by using some example schemas from the JSON Schema website: Link to Figma File -> https://www.figma.com/file/wJHfdNxBeXg4O3jxcqcL9X/JSON-Schema-Wireframes?node-id=7%3A355 What do you think? Am I on the right track? Would appreciate some feedback so I can decide how to proceed! |
Thanks so much for taking the time to record a video 🙏🏼 It helped to check it out quickly 🚀 Only positive feedback, sorry 😄
IMHO it is going a very good direction 🚀 |
Yay! Super glad you thought the video presentation was helpful 😄
Yeah at this stage I was more focused on the interactions and layout of how we might present the information, but I definitely was thinking as I was designing this that we could color-code the property types!
Yes! Glad you found that helpful and easier to read. I was stuck at this for a while trying to figure out the best human approach, and really was just thinking how people are used to seeing rules in math with variables. Interested to see other opinions on this as well!
Bless you for this reference 🙏 As I was working on this, I couldn't help but think that someone must have already done this same kind of thing before but I couldn't find any specific projects similar. I definitely think adding an element like breadcrumbs might be super helpful to keep track of where you are viewing the schema.
I SUPER appreciate your quick and thoughtful feedback, Lukasz! Thank you! 😄 |
Update! Ideation on if/then/else implementationVideo:https://www.loom.com/share/65c5b8fd731d4674bd466b4231b16d52 Transcript:Hey guys, happy Monday. I wanted to just start presenting some more things that I've been coming up with as far as this messages object item in Github. I have a few ideas for if then, else that I would like to present and get some feedback on if possible. TL;DW too long didn't watch: basically these are the three options that I have. This is one where I list the conditions at the bottom outside of the property's object. The next one, where I list the conditions on the left side, where you can toggle between them. And then the last one where I list on the top, where we can toggle between them as well. (For a detailed explanation of these options, view the video on loom which also contains a longer transcript) |
Love it! Have you thought about having tabs inside the property box instead? I mean, when |
Hey @fmvilas thanks for leaving feedback 😄 Whereas the other journey might look like: |
@mcturco Awesome designs as usual ❤️ However I have some doubts looking on examples. I know that it's on early stage and you experiment with some cases, but I see some problems that you sooner or later will catch and you will end up with redesign everything 😅 Trust me, the amount of curses I have uttered over JSON Schema and its flexibility is large enough that I consider myself an expert 🤣 Ok, so:
Let me know if you understand everything I wrote about or if I should describe something more, These problems and edge cases with JSON Schema are a lot. I don't want to scare you but to show that it is a difficult task to make designs for it. Other places like servers etc will be much, much easier, trust me :) |
Wouldn't they also struggle to find what has changed if the tab is on top? I mean, if we have 8 properties and say 4 change. How do you spot them anyway? Two more suggestions/questions:
Oh, BTW, the term you're looking for in the video is |
SOOO thankful for everyone's feedback, I feel like we are really starting to get somewhere promising! I recorded a video feedback if that is okay with you guys. https://www.loom.com/share/540e392a2c9e4235ae1afd7c5048f458 @magicmatatjahu, I addressed your concerns in the video 😄
@fmvilas so we would add the conditions/rules under
Great idea, I have built upon that idea in the video 😄
THANK YOU! I forgot what the word was hahaha |
Yeah, my suggestion is that if it's a condition in Also, with the current approach of putting a dropdown, what if a property is only present when a specific condition is met? You can't select the condition because the property will not be present, right? Maybe the best way to do it after all is to put conditions at a global level 😄 |
Yeah I had the same concern when you were showing me offline how the conditions work in ReDoc. It's cool, but I think it still has some problems that we would need to address.
Yeah that's what I was thinking before when I had the tabs at the global level. I was thinking that it might be easier to discover the "new payload" when that condition is met if we just switched the whole payload based on a tab. However, is there a possibility to have conditions within an object property within payload? It seems like you can, so maybe we have to keep these tabs available at each object level... but that could get confusing. Hmmmmm 🤔 |
In JSON Schema you can't influence the "shape" of JSON Schema from the child's point of view, the parent can it, so I don't think it's problematic. For example, you can influence what is required because of some condition: type: object
properties:
a: ...
b: ...
if:
properties:
a:
const: 'something'
then:
required: [b] so it means that if type: object
properties:
a:
if:
const: 'something'
then:
# how to "see" b property from parent schema?
b: ... I think that approach of Redoc maybe isn't perfect but it renders correctly conditions, in the schema level where conditions are. |
@mcturco Sorry for making you crying at the beginning of video 😆 Sorry also for delay. For first part of union type: I don't know how often people write union as I very like that idea with type: [string, number]
minLength: 1 # related to the string type
format: email
maxValue: 5 # related to the number type When age [string] [number]
{desription of age field}
Rules
The string must have a minimum of 1 character.
Format: email When
For second part about standalone simple schema: yeah, it's make sense to indicate in some way that you have object, string etc. Maybe we should have option to "hide" the property name and only render the type of schema? By this we can reuse the component for objects rendering and render only one property, but you know, with hack that we don't render property of object but simple schema. WDYT? if I am difficult to understand here then let me know. Third part about conditions: Yeah 😆 It was a stupid example, but I answered to Fran's comment about conditions and JSON Schema has big restriction here #618 (comment) In general, it is not possible to change the condition of a "parent" schema in a sub schemas, as I wrote in the example, and so the conditions should be rendered where they are defined - these conditions can affect deeper schemas but no longer on higher ones (their parents). Let me know if this is clear, we can meet and I'll explain it to you with a dozen examples. Or... as you show at the end of video with that Conditions are very difficult to render but we are getting better and better. BTW. I wonder if we should write some library that would simplify given schema to simplifier form, for example removing Great work Missy! 🚀 |
@magicmatatjahu Thank you for your thoughtful and detailed feedback!!! Left some comments below:
🤣
So I originally thought about designing it like this with tabs, but then I was thinking: let's say the property has
Not sure that I fully understand what you mean here 😅 I know what you mean by showing simple schemas, but wouldn't the property name still have to exist? Unless the payload ends up being something like:
Then in that case, yeah, maybe we just simply hide the property name. I can definitely think about this more too and see what other ways we can render this!
Yep, I understand what you are saying here. I think the more challenging problem is the fact that a condition on one property can affect a sibling property, and that could be above or below the property with the condition depending on how someone writes their schema. Which you would hope that someone would be aware that they should probably keep properties with conditions closer to the top, but that might not always be the case. That's why I was thinking having a tab at the global level might make sense, but we can play with some more options. Maybe it would be good just to start with something initially and then see how it works in the application, then iterate on different solutions.
I don't think I understand what you mean here. Do you mean separating the conditions from the normal schema shape?
Thank you so much 😄 Having fun with this problem! |
Just filmed an update video! Would love your thoughts/feedback! We are getting super close to solving this problem 🙏 |
First of all, I love how the discussion is going 👏 I feel that we're really thinking about the problem right now, and that's awesome. So, following your examples with |
I agree!! And I am so appreciative that we are having this conversation as it keeps me from being blocked in my design process!
Cool, so we are all in agreement that this is a good solution for conditions on properties that affect themselves? (not even sure if that statement makes sense haha)
Good point. Here's what I am thinking: Demo: |
I love the concept but I'm afraid we may not have enough horizontal space to have sticky conditions, payload, and examples. And also, potentially, sidebar navigation (when downloaded). What if we render a sticky button near the payload and when you click on it, it displays the conditions panel? Like a sticky menu maybe? Or maybe the whole payload can be contained inside a panel with a toolbar on top. This toolbar would have |
Good point!
LOVE this idea. Going to explore this in the wireframes this week and then I will touch back! |
Okay so I started crafting a layout for the sticky tabs idea that @fmvilas mentioned above, and I think it is starting to come together! The only thing I am unsure of just yet is how to present the conditions at the payload level. Will think through some possible solutions for this, but if you guys have any input here that would be great! Here is a quick demo: And here is the figma prototype link if you want to check it out there: |
Querido GitHub Actions, I hope this message finds you well. Please, kindly wait a bit more for this issue to be solved. Yours faithfully, Fran. |
Hey @mcturco I'm interested to work on this issue! |
Hey Folks, To clarify how to submit a proposal, you should contact the project Mentor/s on Slack and send them your submission in the form of a document or ask them how best they'd prefer you submit your proposals. |
Hey @fmvilas can you assign this to me? |
Had the first work meeting with @mcturco! This week I was mainly going through the entire issue once and studying about JSON Schema, ngl it's pretty complex but I'm getting there 😄. So meeting notes:
Basically, if a user makes a change following certain rules, a quick message will show up on the side. This message will let them know that specific things have been changed throughout the whole document. Will think through some possible solutions for this, but if you folks have any input here that would be great!
|
@asmitbm why not share it with the community on slack too :) |
Hey @AceTheCreator, sure I was going to share it on Slack once I had done a little more progress. Will post the update here today and then link the discussion on Slack. |
Progress update since last week:
So, the idea here is whenever the user will make any changes in the conditional logic, an alert pop-up box will appear at the top. It can be there for 5 seconds or until the user decides to disable it.
Here, the alerts will appear in the blank space under "Examples", thus notifying users about the changes that occurred in the documentation. If you folks have any input, that would be great! |
@asmitbm I like this idea of using a toast! A couple of questions:
Keep up the great work! 🎉 |
Hey @mcturco, thank you for the feedback :) Answering your questions:
We can place this toast alert at the top like browser alerts and highlight the box with warning color. If it's possible, we can even include a line number, just like in the terminal errors. My idea here is to briefly highlight the updated properties, along with triggering a pop-up toast alert as soon as the user modifies any element within the payload.
It can be like when Figma shows a quick highlight for prototypes that are ready to use. |
This week's update:
When we have multiple union typesHere I created badges for each union type i.e Using actual example from the portalI used the "lightMeasurePayload" object from Streetlights API. I also used badges to group the types. Now, when it comes to the part about Conditional Logic, I tried to explain it in a simple way like how we learn basic CS Fundamentals intead of using numbers and variables. While I was doing this, I had a thought: What if users want to pick certain conditions? In this case, I've added radio buttons that allows users to choose specific conditions provided by the payload. With these radio buttons, users can pick different conditions and use the alert system mentioned earlier. This way, users can experiment with various conditions and receive alerts each time they make a change. If you folks have any suggestions, I would be glad to hear and implement them. Thank you for your patience! |
String values can also have conditional logic. For instance, if the string is "dog" then X, else if "cat" then Y, etc. I like the direction this is heading. My only concern is those one-liner radio buttons. Both the "if" and "then" parts can get really large to make it fit in a single line. What about we offer a dropdown with lots of "ifs" (minimum >= 100, minimum >= 10, etc.) but the "then" part is below? This might make it easier to read and fit larger conditions. What do you think? Great stuff 👏 |
Hey everyone, Sorry for late update, was caught up with university stuff. So, here's the summary of call I had with Fran. A collapsible sidebar for conditionsAfter our recent meeting, we discussed the idea of presenting all the conditions at the top as a tab. This would provide users with an overview of the conditions contained within the payload. Based on my UX research, I discovered that toggling between the payload and conditions tab could potentially disrupt the user experience and cause users to overlook certain conditions. As a solution, I proposed implementing a collapsible sidebar for the conditions. Here, you'll find all the conditions listed on the left side of the payload. The concept behind this design is that as the user scrolls through the payload component, the conditions window will scroll in sync with it. By implementing this feature, users will consistently have visibility into the valid conditions associated with the specific payload they are examining. The issue we encountered here is the horizontal space demands of the conditions tab, which could potentially lead to cluttering on smaller screens. Fran and I explored the idea of introducing a dropdown menu for conditions, wherein the conditions for a particular payload would be listed in a dropdown format. Will update the design and post it here next week! |
Collective update of last two meetings. Incorporating feedback from Missy and Fran, I revised the designs, and I will now proceed to describe them individually. Rendering conditions as a dropdown boxI moved the 'conditions' button to the horizontal navigation bar, right next to 'payload' and 'raw schema.' The 'conditions' tab is now a dropdown menu that displays all the conditions in a scrollable list. Here's what it will look like when it's expanded. The issue that Missy and I pointed out is that it would result in a poor user experience, as users wouldn't be able to see the payload behind the expanded conditions box. After further discussion, Missy suggested that I go back to the previous idea, which is to have the conditions as a scrollable column next to the payload. Rendering conditions as a separate columnHere, I've left the condition tab in the same spot, but I've adjusted the design to accommodate the scrollable conditions list. We encountered some space-related issues again, so Missy suggested moving the examples under each condition when the conditions view is expanded. This way, both the payload and conditions columns will have equal space on the screen. The next design update will involve showing examples under each condition and organizing sub-properties in a tree-like structure. If any of you have suggestions, I'm open to hearing and implementing them. Thank you for your patience! |
Collective update from last few meetings. The last time we examined various ways to display information in the Conditions tab. Missy had provided some comments on the Figma file, and I made a few additional adjustments based on her feedback. Collapsible Side Navigation BarThis idea for the sidebar navigation is from the latest design trend in products like Arc browser and Notion. By using this approach, we can use the entire screen to display content to users in a more user-friendly manner. Collapsible PanelsBuilding on the previous design, I opted to include payload documentation and raw schema in distinct tabs within the side navigation bar. This allows users to effortlessly switch between the two. Perhaps, each panel could have its own tab, such as Payload, Conditions, Examples, and Raw Schema. Each tab should likely include a title and an option to minimize or close. Multiple ObjectsUntil now, we've been designing for a single object and its properties. However, to ensure compatibility with future updates, there will be multiple objects stacked one below the other. That's why I introduced collapsible objects, making it simpler for users to:
Nested ObjectsMissy gave an example of nested objects and demonstrated how AsyncAPI Studio currently deals with them. I then experiemented how the payload would appear if there was an object with properties, and inside that, another object. In this design, I arranged nested objects in a file-folder structure. While it effectively communicates that it's a nested object, I encountered a limitation. There won't be sufficient space to display the content inside, and it could become quite complex when there are multiple objects. In this design, I stuck with the structure that AsyncAPI Studio currently uses, but we revamped all the labels and conditions, making it look much neater and more polished. If you have any more suggestions about nesting, I would be happy to hear and implement. Thank you for all your patience! |
This issue has been automatically marked as stale because it has not had recent activity 😴 It will be closed in 120 days if no further activity occurs. To unstale this issue, add a comment with a detailed explanation. There can be many reasons why some specific issue has no activity. The most probable cause is lack of time, not lack of interest. AsyncAPI Initiative is a Linux Foundation project not owned by a single for-profit company. It is a community-driven initiative ruled under open governance model. Let us figure out together how to push this issue forward. Connect with us through one of many communication channels we established here. Thank you for your patience ❤️ |
Hello @asmitbm, is this issue still ongoing? |
This issue has been automatically marked as stale because it has not had recent activity 😴 It will be closed in 120 days if no further activity occurs. To unstale this issue, add a comment with a detailed explanation. There can be many reasons why some specific issue has no activity. The most probable cause is lack of time, not lack of interest. AsyncAPI Initiative is a Linux Foundation project not owned by a single for-profit company. It is a community-driven initiative ruled under open governance model. Let us figure out together how to push this issue forward. Connect with us through one of many communication channels we established here. Thank you for your patience ❤️ |
Description
This issue is for the design progress and proposal of the UX/UI updates to the Messages Object documentation output.
Scope
See comments below for design progress.
The text was updated successfully, but these errors were encountered: