-
Notifications
You must be signed in to change notification settings - Fork 32
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
feat: Chart responsible for its own theme #1772
feat: Chart responsible for its own theme #1772
Conversation
Codecov ReportAttention:
Additional details and impacted files@@ Coverage Diff @@
## main #1772 +/- ##
==========================================
- Coverage 46.07% 46.05% -0.03%
==========================================
Files 628 628
Lines 37781 37771 -10
Branches 9516 9512 -4
==========================================
- Hits 17409 17394 -15
- Misses 20317 20323 +6
+ Partials 55 54 -1
Flags with carried forward coverage won't be shown. Click here to find out more. ☔ View full report in Codecov by Sentry. |
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 like the padding on the styleguide snapshots got a little smaller for the charts. I'm guessing it's fine, but wanted to make sure it was a known change
} else if (plotStyle === dh.plot.SeriesPlotStyle.PIE) { | ||
seriesData.textinfo = 'label+percent'; |
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.
Do we want to move the other trace specific things to the template where possible? Could be a separate ticket
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.
Possibly? Since there are some things that will have to stay here, I'm not too worried about it.
this.layout = { | ||
grid: { | ||
rows: figure.rows, | ||
columns: figure.cols, | ||
pattern: 'independent', | ||
}, | ||
template, | ||
template: this.chartUtils.makeDefaultTemplate(theme), |
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 would be ideal if the model didn't need the theme at all, but looks like it does for some dynamic axis stuff still.
You should be able to remove the template at least because it's overridden by Chart
anyway
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 did a bit of testing and you can remove theme from the updateFigureAxes
call. The only spot where it ends up using it is to set the axis if one doesn't exist, but plotly applies from the template in that case it seems.
Just to test, get a subplotting example from here and then change something in makeLayoutAxis
. I made the y axis zerolinecolor
red and it properly applied to both series even w/o the assignment in updateLayoutAxes
That then leaves just the error bars in the model which I bet can remove the theme as well since you added it to the default template. I couldn't find a good example on the docs to test this though
* Fix some issues with plotly types. | ||
*/ | ||
|
||
declare module 'plotly.js' { |
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.
Can this go in the root @types
folder? I'd try putting it there to see if you get the same results. It is meant to serve as a central types override
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 doesn't seem to merge with the existing Plotly types when I do this
bc5717f
to
3aab67e
Compare
This is a known change. The styleguide was overriding some of the default layout. Now that we have moved to template.layout, the defaults properly stay in place. |
packages/chart/src/ChartUtils.ts
Outdated
if (layout[axisLayoutProperty] == null) { | ||
layout[axisLayoutProperty] = this.makeLayoutAxis(axisType, theme); | ||
} |
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 wonder if this should set the axis to an empty object instead by default. Then the template part would still be applied by the template, but any other axis specifics (like range I think) should get applied to the axis. The code after calls updateLayoutAxis
only if the axis exists. In subplots, the axis wouldn't exist (but it does seem to get created somewhere, I just don't know where)
layout: {
xaxis: ...,
xaxis2: { range: ... },
template: {
layout: {
xaxis: { styleStuff }
}
}
}
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.
Good call. Doing this allowed me to restore most of the full tests I had deleted before which feels better to me.
d278f1a
to
caeb348
Compare
This PR
layout.template.layout
so that they are used as defaults. Some of the theme colors had to be set inlayout.template.data
for specific trace typesTesting
For now, we should just make sure charts behave as they did before. Not all charts will update in response to a theme change, but re-running queries should show the theme change. I have tested this and have not seen any changes to existing behavior introduced by this PR
Once the following plugins repo PRs have merged, the chart should fully respond to theme changes:
deephaven/deephaven-plugins#243
deephaven/deephaven-plugins#251
resolves #1728
BREAKING CHANGE:
ColorUtils.getColorwayFromTheme
tonormalizeColorway
chartTheme
arg from functions inChartUtils
,ChartModelFactory
andFigureChartModel
in @deephaven/chart