-
Notifications
You must be signed in to change notification settings - Fork 8.3k
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
[Runtime field editor] Preview field against cluster data #101398
[Runtime field editor] Preview field against cluster data #101398
Conversation
Pinging @elastic/kibana-stack-management (Team:Stack Management) |
Pinging @elastic/kibana-app-services (Team:AppServices) |
@yuliacech I've added the overlay to the flyout and now I get the following accessibility issue (basically that the menu on the left is not clickable anymore). Have you solved this somewhere?
Full error: https://github.com/elastic/kibana/pull/101398/checks?check_run_id=2764396828 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So awesome to see this coming to life, @sebelga! Awesome work. Some comments as follows:
Preview panel position
The position of the preview panel has been under discussion and potential trade offs have been raised. Upon further feedback from kibana-design team, I am suggesting we keep position per original design (on the right), add a transition, and assess again when implemented to get the actual feel for the trade offs. The primary rationale is expected hierarchy, and the natural flow of disclosing information from left to right is more intuitive and may warrant (or even be clarified by) shifting the content to afford expansion.
Close vs Cancel
Suggest removing the X button (hideCloseButton), renaming close
to Cancel
in the footer, and adding a confirmation dialog to the Cancel action if user has entered any fields. This would more clearly present the cause and effect of each action.
Panel width
The main panel section adjusting in width when the preview panel appears is not ideal. It would be better to keep the width or modify from onset if real estate is of concern.
Preview table row height
The table row height seems uncommon. Standard EUI table row height would be preferred.
Field highlighting
Suggest bolding the new preview field in addition to the background highlight to help with contrast accessibility.
Preview panel empty state
There seems to be a typo in the empty prompt. "..of our new fields will appear".
Bug?
Clearing name
does not return preview error, as it seems it should.
Bug?
Calculation doesn't work for me. Please let me know if I am testing incorrectly.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
src/plugins/index_pattern_field_editor/public/components/preview/documents_nav_preview.tsx
Outdated
Show resolved
Hide resolved
src/plugins/index_pattern_field_editor/public/components/preview/documents_nav_preview.tsx
Outdated
Show resolved
Hide resolved
src/plugins/index_pattern_field_editor/public/components/preview/field_list/field_list.tsx
Show resolved
Hide resolved
src/plugins/index_pattern_field_editor/public/components/preview/field_preview.tsx
Outdated
Show resolved
Hide resolved
Pinging @elastic/apm-ui (Team:apm) |
Pinging @elastic/uptime (Team:uptime) |
💚 Build SucceededHistory
To update your PR or re-run it, just comment with: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks great @sebelga. Per our discussion, let's track the following enhancements in subsequent PR:
- Panel transition
- Error callout icon (
alert
instead ofcross
)
We will also investigate additional outstanding UX questions discussed in upcoming user validation sessions.
Thanks for the review @dborodyansky ! Yes let's continue the UX improvement in separate PRs. 👍 |
bb321e6
into
elastic:runtime-field-editor/preview-field-workstream
This PR adds the previewing of the runtime field in the context of the latest documents from the index pattern.
When we open the index pattern field editor we load the latest 50 documents from the cluster and display in the Preview panel their fields (initially we only display the first 7 fields).
The error handling currently in place is basic and will be improved on as a separate chunk of work.
Notes on implementation
I have used a virtual list to render the list of fields. This allows the UI to support huge list of fields (5000+) that can occur in certain scenarios. This implies that the list items must have a fix height and that we give an height to the scrollable area.
The height is calculated dynamically with a
<EuiResizeObserver />
and passed down to the<VirtualList />
component so we can make use of the full height of the flyout panel to render the fields on any screen size.How to test
Make sure to load the Kibana sample data logs
Navigate to the index pattern management app and select the "kibana_sample_data_logs" index pattern
Click "Add field"
Give a name to the field and toggle the "Set value"
The Preview pannel should open with the empty prompt
Add a script (e.g.
emit("hello")
)The Preview panel should update and display the runtime field (name and value) along with the other documents fields
Click the "Show more" button to display all the fields
The fields should expand and you should be able to scroll all the fields.
Now let's do some calculation with our script: change the field type to "long" and the script to
emit(doc['bytes'].value * 2)
The preview should correctly show the double that what the "bytes" field indicates.
Change the document ID and provide a wrong ID
There should be an error
Now enter a valid ID (e.g. "pyDLo3kBEdBikFTNyctP")
You should see that document in the preview and the "Previous" / "Next" button should not be visible anymore
Click on the "Load documents from cluster" button
You should be back navigating the list of documents loaded from the cluster
Test with 5000 fields
As we are using a virtual list, the number of fields do not have a performance impact in the rendering.
Open the
field_list.tsx
file and replace thefieldsValues
declaration block on L49 withChanges to the Core public API
This is a minor change.
I have added the
hideCloseButton
EuiFlyoutProp to be able to hide the close button in the flyout when using theoverlays.openFlyout()
core handler.Upcoming work to be done
Screenshots