-
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
[Lens] Allow visualizations to provide a dimension editor #67560
[Lens] Allow visualizations to provide a dimension editor #67560
Conversation
Pinging @elastic/kibana-app (Team:KibanaApp) |
@elasticmachine merge upstream |
@wylieconlon good job! In this PR you're putting vis dimension editor right below the datasource dimension editor, don't we need a design for it for the placement? Another option would be separate tab. I am happy with merging it now and improving later. |
mockDatasource = createMockDatasource('ds1'); | ||
}); | ||
|
||
it('should fail to render if the public API is out of date', () => { |
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.
I don't understand this test. Could you explain? 🙏
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.
It's testing another one of the edge cases in rendering, where the known layers don't match. This tests that when rendering layer first
without any information about that ID, it doesn't throw errors.
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.
tested if it doesn't break anything and with adding a very silly implementation of renderDimensionEditor
:
renderDimensionEditor (domElement,props ){
render(<div>DimensionEditor</div>,
domElement
);
},
Based on the mock from #53660, the configurations need to be rendered to the right of the aggregations list, not below. |
@cchaos I don't think that's a realistic option because of the separate ownership of the two areas: The top section is entirely rendered by the datasource, and the bottom section is entirely rendered by the visualization. |
Then we will need to move quicker towards the next phase which is using Tabs to separate calculation and style/formatting concerns. The mock below shows two tabs, one where it's simply the aggregation and it's configurations, the other is for coloring and other stylistic options that are not necessarily tied to the aggregation type. Actual content subject to change. cc @AlonaNadler I'm trying to avoid such a large void where there is no content and as the list of possible aggregations grows, that void will too. |
@cchaos Tabs are possible, but we aren't going to have very many options at the beginning. Imagine having a "Format & Style" tab with only one setting- is that acceptable? |
Yep! It's better for the user than moving UI a bunch. |
…ibana into lens/extra-dimension-panel
@cchaos done |
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.
Thanks @wylieconlon! Now we have a good place to start adding in style customizations.
defaultMessage: 'Format & style', | ||
}), | ||
content: ( | ||
<div className="lnsVisualizationDimensionEditor"> |
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.
Nit for BEM naming
<div className="lnsVisualizationDimensionEditor"> | |
<div className="lnsLayerPanel__styleEditor"> |
If I see this correctly, each visualization can only register a dimension editor for all dimensions at once, so if a visualization only needs this this in certain places (but not in all of them), an empty tab would be rendered, correct? E.g. let's say we implement fitting function next, this makes only sense for the current x axis dimension, so the dimension editor would be empty for y axis dimensions, but the tab would still be rendered, right? IMHO we should provide a way to not render a tab as well. Maybe having an optional property shouldRenderDimensionEditor( props: VisualizationConfigProps<T> & {
groupId: string;
accessor: string; }): boolean; as well. |
Maybe better: Another option would be to provide a list of groups you want the editor to show. That would discourage developers from showing the tab and hiding it based on configuration of the dimension (which would be confusing for end users). |
@flash1293 It sounds like we already have a solution for this, which is based on the way dimension groups are defined by the visualization. I can add something for this. |
@wylieconlon I see, making this part of |
💚 Build SucceededHistory
To update your PR or re-run it, just comment with: |
) * [Lens] Allow visualizations to provide a dimension editor * Update to tab style * Remove table update * Update class name * typecheck fix * Add test * Require each dimension group to enable editor Co-authored-by: Elastic Machine <[email protected]> Co-authored-by: Marta Bondyra <[email protected]>
…67885) * [Lens] Allow visualizations to provide a dimension editor * Update to tab style * Remove table update * Update class name * typecheck fix * Add test * Require each dimension group to enable editor Co-authored-by: Elastic Machine <[email protected]> Co-authored-by: Marta Bondyra <[email protected]> Co-authored-by: Elastic Machine <[email protected]> Co-authored-by: Marta Bondyra <[email protected]>
This sets up an optional function
renderDimensionEditor
which can be provided by visualizations to add extra configuration to a specific dimension. None of these new editors are added in the PR, but this sets up future work that would let the user change the axis, text alignment, color, or other visualization-specific styles.When there is no editor registered, only one tab is shown:
Closes #67225
Checklist
Delete any items that are not applicable to this PR.