Releases: plotly/dash
Dash v2.6.1
Fixed
- #2175 Fix #2173 callback output of ndarray and no_update check.
- #2146 Remove leftover debug console.log statement.
- #2168 Reverts #2126 (supporting redirect from root when using pages) until the new bugs introduced by that PR are fixed.
Updated
- #2167 Update Plotly.js to v2.13.3 (from v2.13.1) including patch release v2.13.2 and patch release v2.13.3.
- Emit
plotly_selectedevent on plot API calls and GUI edits. - Fix
sankeyselect error (regression introduced in 2.13.0). - Handle missing drag layer of invisible
sankeytraces to fix select error. - Emit selection event in shape drawing
dragmodes when an existing selection is modified.
- Emit
Dash v2.6.0
Added
- #2109 Add
maxHeightto Dropdown options menu. - #2039 Long callback changes:
- Add
background=Falsetodash.callbackto use instead ofapp.long_callback. - Add previous
app.long_callbackarguments todash.callback(interval,running,cancel,progress,progress_default,cache_args_to_ignore,manager)
- Add
- #2110 Add
searchprop todcc.Dropdownoptions, allowing to search the dropdown options with something other than the label or value.
Fixed
- #2126 Fix bug where it was not possible to redirect from root when using pages.
- #2114 Fix bug #1978 where text could not be copied from cells in tables with
cell_selectable=False. - #2102 Fix bug as reported in dash-labs #113 where files starting with
.were not excluded when buildingdash.page_registry. - #2100 Fixes bug where module name in for a custom
not_found_404page is incorrect in thedash.page_registrywhen not using thepagesfolder. - #2098 Accept HTTP code 400 as well as 401 for JWT expiry
- #2097 Fix bug #2095 with TypeScript compiler and
React.FCempty valueDeclaration error & support empty props components. - #2104 Fix bug #2099 with Dropdown clearing search value when a value is selected.
- #2039 Fix bugs in long callbacks:
- #2110 Fix
dcc.Dropdownsearch with component as prop for option label. - #2131 Add encoding to file open calls. Fix bug #2127.
Changed
- #2116 Rename long callbacks to background callbacks
- Deprecated
dash.long_callback.managers.CeleryLongCallbackManager, usedash.CeleryManagerinstead. - Deprecated
dash.long_callback.managers.DiskcacheLongCallbackManager, usedash.DiskcacheManagerinstead. - Deprecated dash constructor argument
long_callback_managerin favor ofbackground_callback_manager.
- Deprecated
Updated
- #2134 Upgrade Plotly.js to v2.13.1 (from v2.12.1) including feature release 2.13.0 and patch release 2.13.1
- Add persistent selections via layout attributes
selections,newselection, andactiveselection, along with an updated UI allowing you to modify a selection you created. - Add unselected line styling to
parcoordstraces. - Add more quartile algorithms to
violintraces. - More flexible axis
automarginbehavior. - And several other enhancements and bug fixes.
- Add persistent selections via layout attributes
Dash v2.5.1
Fixed
- #2087 Fix bug #2086 in which using id as a key within a component's id breaks the new callback context's
args_groupingfunction. - #2084 In dash 2.5.0, a default viewport meta tag was added as recommended for mobile-optimized sites by mdn
This feature can be disabled by providing an empty viewport meta tag. e.g.app = Dash(meta_tags=[{"name": "viewport"}]) - #2090, #2092. Fixed bug where the
pathto thepages_folderwas incorrect on Windows.
Removed
- #2087 Removed the undocumented callback context
args_grouping_valuesproperty which was incompatible with pattern-matching callbacks.
Dash v2.5.0
Added
- #1947 Added
pages- a better way to build multi-page apps. For more information see the forum post. - #1965 Add component as props.
- #2049 Added
wait_for_class_to_equalandwait_for_contains_classmethods todash.testing
Changed
- #2050 Changed
find_elementandfind_elementsto accept anattributeargument that aligns with Selenium'sByclass, allowing you to search elements by other attributes. Default value isCSS_SELECTORto maintain backwards compatibility with previousfind_elements.
Fixed
- #2043 Fix bug
#2003 in which
dangerously_allow_html=True+mathjax=Trueworks in some cases, and in some cases not. - #2065 Fix bug #2064 rendering of
dcc.Dropdownwith a value but no options. - #2047 Fix bug #1979 in which
DASH_DEBUGas environment variable gets ignored. - #2070 Fix bug #2066 nested types triggering maximum call stack error when building typescript components.
Dash v2.4.1
Fixed
- Fix #2045 import error when using pytest but
dash[testing]is not installed.
Dash v2.4.0
Added
-
#1952 Improved callback_context
- Closes #1818 Closes #1054
- adds
dash.ctx, a more concise name fordash.callback_context - adds
ctx.triggered_prop_ids, a dictionary of the component ids and props that triggered the callback. - adds
ctx.triggered_id, theidof the component that triggered the callback. - adds
ctx.args_grouping, a dict of the inputs used with flexible callback signatures.
-
#2009 Add support for Promises within Client-side callbacks as requested in #1364.
-
#1956 Add TypeScript components generation.
-
#2034 Add
link_targetprop to dcc.Markdown component. Closes #1827 -
#2035 Add type annotations to testing fixtures.
Fixed
-
#2029 Restrict the number of props listed explicitly in generated component constructors - default is 250. This prevents exceeding the Python 3.6 limit of 255 arguments. The omitted props are still in the docstring and can still be provided the same as before, they just won't appear in the signature so autocompletion may be affected.
-
#1968 Fix bug #1877, code which uses
merge_duplicate_headersandstyle_header_conditionalto highlight columns, it incorrectly highlights header cells. -
#2015 Fix bug #1854 in which the combination of row_selectable="single or multi" and filter_action="native" caused the JS error.
-
#1976 Fix #1962 in which DatePickerSingle and DatePickerRange are extremely slow when provided a long list of disabled_days.
-
#2035 Fix #2033 In-App error reporting does not render HTML.
-
#1970 dcc.Dropdown Refactor fixes:
Changed
-
#1751 Rename
app.run_servertoapp.runwhile preservingapp.run_serverfor backwards compatibility. -
#1839 The
callbackdecorator returns the original function, not the wrapped function, so that you can still call these functions directly, for example in tests. Note that in this case there will be no callback context so not all callbacks can be tested this way. -
#2016 Drop the 375px width from default percy_snapshot calls, keep only 1280px
-
#2027 Improve the error message when a user doesn't wrap children in a list
Updated
- #2016, #2032, and #2042 Widespread dependency upgrades
- Upgrade Plotly.js to v2.12.1 (from v2.11.0).
- Upgrade
blackto v22.3.0 for Python 3.7+ - if you usedash[ci]and you callblack, this may alter your code formatting slightly, including more consistently breaking Python 2 compatibility. - Many other mainly JS dependency upgrades to the internals of Dash renderer and components. These may patch bugs or improve performance.
Dash v2.3.1
Dash v2.3.0
Added
- #1949 Add built-in MathJax support to both
dcc.Markdownanddcc.Graph. A new boolean propmathjaxwas added to these two components, defaulting toFalse. Setmathjax=Trueto enable math rendering. This work uses MathJax v3, althoughdcc.Graphand Plotly.js can also be used with MathJax v2.- In
dcc.Markdownthis has two flavors: inline math is any content between single dollar signs, for example"$E=mc^2$", and "display" math (on its own line, potentially multi-line) is delimited by double dollar signs. - In
dcc.Graph, most text fields (graph and axis titles, trace names, scatter and bar text) can use math, and it's enabled with single dollar sign delimiters. A limitation here is that currently a given piece of text can only be one or the other: if math is found, everything outside the delimiters is ignored. See https://plotly.com/python/LaTeX/ for details. - For an intro to LaTeX math, see https://en.wikibooks.org/wiki/LaTeX/Mathematics.
- Big thanks to Equinor for sponsoring this development, including the related work in Plotly.js!
- In
Updated
- #1949 Upgrade Plotly.js to v2.11.0 (from v2.9.0)
- Feature release 2.10.0:
- Support for MathJax v3
fillpatternforscattertraces with filled area
- Feature release 2.11.0:
- Every trace type can now be rendered in a stricter CSP environment, specifically avoiding
unsafe-eval. Please note: theregl-based traces (scattergl,scatterpolargl,parcoords, andsplom) are only strict in thestrictbundle, which is NOT served by default in Dash. To use this bundle with Dash, you must either download it and put it in yourassets/folder, or include it as anexternal_scriptfrom the CDN: https://cdn.plot.ly/plotly-strict-2.11.0.min.js. All other trace types are strict in the normal bundle.
- Every trace type can now be rendered in a stricter CSP environment, specifically avoiding
- Patch release 2.10.1 containing a bugfix for
mesh3dtraces.
- Feature release 2.10.0:
Fixed
-
#1915 Fix bug #1474 when both dcc.Graph and go.Figure have animation, and when the second animation in Figure is executed, the Frames from the first animation are played instead of the second one.
-
#1953 Fix bug #1783 in which a failed hot reloader blocks the UI with alerts.
-
#1942 Fix bug #1663 preventing pie traces from sending
customdatawithclickDataand other events.
Dash v2.2.0
Added
- #1923:
dash.get_relative_pathdash.strip_relative_pathdash.get_asset_url
This is similar todash.callbackwhere you don't need theappobject. It makes it possible to use these
functions in thepagesfolder of a multi-page app without running into the circularappimports issue.
Updated
-
#1911 Upgrade Plotly.js to v2.9.0 (from v2.8.3).
- Adds
ticklabelstepto axes to reduce tick labels while still showing all ticks. - Displays the plotly.js version when hovering on the modebar. This helps debugging situations where there might be multiple sources of plotly.js, for example
/assetsvs the versions built intodccorddk.
- Adds
-
#1930 Upgrade JavaScript dependencies across renderer and all components.
Fixed
Dash v2.1.0
Changed
-
#1876 Delays finalizing
Dash.configattributes not used in the constructor untilinit_app(). -
#1869, #1873 Upgrade Plotly.js to v2.8.3. This includes:
- Feature release 2.5.0:
- 3D traces are now compatible with
no-unsafe-evalCSP rules.
- 3D traces are now compatible with
- Feature release 2.6.0:
- Add
smithsubplots andscattersmithtraces, for drawing Smith charts.
- Add
- Feature release 2.7.0:
- Add text data for
histogramtraces. - Fix an interaction between
uirevisionandautorangethat pops up in some cases of mixed clientside / serverside figure generation.
- Add text data for
- Feature release 2.8.0:
- Add horizontal colorbars.
- Add text data on
heatmapand related trace types. - Control legend group title fonts.
- Patch releases 2.5.1, 2.6.1, 2.6.2, 2.6.3, 2.6.4, 2.8.1, 2.8.2, and 2.8.3 containing bugfixes.
- This PR also upgrades various other dependencies of dash renderer and component suites.
- Feature release 2.5.0:
-
#1745:
Improve ourextras_require: there are now five options here, each with a well-defined role:dash[dev]: for developing and building dash components.dash[testing]: for using thepytestplugins in thedash.testingmoduledash[diskcache]: required if you useDiskcacheLongCallbackManagerdash[celery]: required if you useCeleryLongCallbackManagerdash[ci]: mainly for internal use, these are additional requirements for the Dash CI tests, exposed for other component libraries to use a matching configuration.
Added
-
#1883 in DataTable added
page_currenttopersisted_propsas requested in #1860 -
Dash and Dash Renderer
Input,State, andOutputnow accept components instead of ID strings and Dashcallbackwill auto-generate the component's ID under-the-hood if not supplied. This allows usage like:
my_input = dcc.Input() my_output = html.Div() app.layout = html.Div([my_input, my_output]) @dash.callback(Output(my_output, 'children'), Input(my_input, 'value')) def update(value): return f'You have entered {value}'
Or, if using Python >=3.8 you can use the
:=walrus operator:app.layout = html.Div([ my_input := dcc.Input(), my_output := html.Div() ]) @dash.callback(Output(my_output, 'children'), Input(my_input, 'value')) def update(value): return f'You have entered {value}'
#1894 restricted this feature so auto-generated IDs are not allowed if the app uses
dash_snapshots(a Dash Enterprise package) or if the component usespersistence, as this can create confusing errors. Callback definitions can still reference components in these cases, but those components must have explicit IDs.Dash Core Components
Rearranged Keyword Arguments & Flexible Types
Dropdown,RadioItem, andChecklist- Rearranged Keyword Arguments -
options&valueare now the first two keywords which means they can be supplied as positional arguments without the keyword. Supplying the keywords (options=andvalue=) is still supported. - Flexible Types -
optionscan be supplied in two new forms:- An array of
string|number|boolwherelabelandvalueare equal to the items in the list. - A dictionary where the keys and values set as
valueandlabelrespectively.
- An array of
Before:
dcc.Dropdown( options=[ {'label': 'New York', 'value': 'New York'}, {'label': 'Montreal', 'value': 'Montreal'}, ], value='New York' )
or
dcc.Dropdown( options=[ {'label': 'New York', 'value': 'NYC'}, {'label': 'Montreal', 'value': 'MTL'}, ], value='New York' )
After:
dcc.Dropdown(['New York', 'Montreal'], 'New York')
Or
dcc.Dropdown({'NYC': 'New York', 'MTL': 'Montreal'}, 'New York')
RangeSlider&Slider- Rearranged Keyword Arugments -
min,max, andstepare now the first three keyword arguments which means they can be supplied as positional arguments without the keyword. - Flexible Types
stepwill be calculated implicitly if not given.markswill be auto generated if not given. It will useminandmaxand will respectstepif supplied. Auto generated marks labels are SI unit formatted. Around 5 human-readable marks will be created.- To remove the Slider's marks, set
marks=None.
Before:
dcc.Slider(marks={1: 2, 2: 2, 3: 3})
After:
dcc.Slider(min=1, max=3, step=1)
Or equivalently:
dcc.Slider(1, 3, 1)
Step can also be omitted and the
Sliderwill attempt to create a nice, human readable step with SI units and around 5 marks:dcc.Slider(0, 100)
The SI units and ranges supported in
marksare:µ- micro, 10⁻⁶m- milli, 10⁻³(none) - 10⁰k- kilo, 10³M- mega, 10⁶G- giga, 10⁹T- tera, 10¹²P- peta, 10¹⁵E- exa, 10¹⁸
Ranges below 10µ are not supported by the Slider. This is a bug: #1766
DataTable- Rearranged Keyword Arguments -
dataandcolumnsthe first twokeyword arguments which means they can be supplied as positional arguments without the keyword. - Inferred Properties - If
columnsisn't supplied then it is extracted from the the first row indata
Before:
dash_table.DataTable(data=df.to_dict('records'), columns=[{'name': i, 'id': i} for i in df.columns])
After:
dash_table.DataTable(data=df.to_dict('records'))
New Component Properties
Checklist&RadioItems- A new property
inlineappendsdisplay: inline-blocktolabelStyle.
dcc.Checklist(inline=True)
Fixed
-
#1879 Delete redundancy in pattern-matching callback implementation, specifically when
ALLandMATCHwildcards are used together. This patch was submitted by an anonymous Dash Enterprise customer. Many thanks! -
#1858 Support
mini-css-extract-pluginWebpack plugin with@plotly/webpack-dash-dynamic-importnode package - used by components to support dash async chunks. Updated dependencies of other@plotlynode packages. -
#1836 Fix
__all__in dcc and table for extras: dcc download helpers and table format helpers. This also restores this functionality to the obsolete top-level packagesdash_core_componentsanddash_table. -
#1822 Remove Radium from renderer dependencies, as part of investigating React 17 support.
-
- Clean up our handling of serialization problems, including fixing
orjsonfor Python 3.6 - Added the ability for
dash.testingpercy_snapshotmethods to choose widths to generate.
- Clean up our handling of serialization problems, including fixing
-
#1778 DataTable: Fix React warnings stating
that each child in a list should have a unique "key" prop -
#1895 Support debug=True if native namespace-packages are present