Migration from @material-ui/pickers
@material-ui/pickers
was moved to the @mui/lab
.
This guide is an overview of the core concepts that were changed from pickers v3.2.10.
Installation
You need to install the @mui/lab
package if it's not already installed.
⚠️ Make sure you have installed a version between v5.0.0-alpha.30
and v5.0.0-alpha.89
inclusively.
Imports
The keyboard
version of pickers is no longer published. All versions of mobile and desktop pickers implement keyboard input for accessibility.
<span class="token deleted-sign deleted"><span class="token prefix deleted">-</span><span class="token line">import { KeyboardDatePicker } from '@material-ui/pickers';
</span></span><span class="token inserted-sign inserted"><span class="token prefix inserted">+</span><span class="token line">import DatePicker from '@mui/lab/DatePicker';
</span></span>
<span class="token deleted-sign deleted"><span class="token prefix deleted">-</span><span class="token line"><KeyboardDatePicker />
</span></span><span class="token inserted-sign inserted"><span class="token prefix inserted">+</span><span class="token line"><DatePicker /></span></span>
Also, instead of providing a variant
prop, these were moved to different imports, meaning that your bundle won't include Dialog
if you are using only the desktop picker.
<DesktopDatePicker />
– Only desktop view.<MobileDatePicker />
– Only mobile view.<DatePicker />
– Mobile or Desktop view according to the user pointer preference.<StaticDatePicker />
– The picker view itself, without input or any other wrapper.
<span class="token deleted-sign deleted"><span class="token prefix deleted">-</span><span class="token line">import { DatePicker } from '@material-ui/pickers';
</span></span><span class="token inserted-sign inserted"><span class="token prefix inserted">+</span><span class="token line">import DesktopDatePicker from '@mui/lab/DesktopDatePicker';
</span></span>
<span class="token deleted-sign deleted"><span class="token prefix deleted">-</span><span class="token line"><DatePicker variant="inline" />
</span></span><span class="token inserted-sign inserted"><span class="token prefix inserted">+</span><span class="token line"><DesktopDatePicker /></span></span>
The same convention applies to TimePicker
– <DesktopTimePicker>
and <MobileTimePicker />
.
MuiPickersUtilsProvider
The MuiPickersUtilsProvider
was removed in favor of LocalizationProvider
. Also, pickers do not require you to install date-io adapters manually. Everything is included with the lab
.
❌ Before:
<span class="token keyword">import</span> AdapterDateFns <span class="token keyword">from</span> <span class="token string">'@date-io/date-fns'</span><span class="token punctuation">;</span>
<span class="token keyword">import</span> <span class="token punctuation">{</span> MuiPickersUtilsProvider <span class="token punctuation">}</span> <span class="token keyword">from</span> <span class="token string">'@material-ui/pickers'</span><span class="token punctuation">;</span>
✅ After:
<span class="token keyword">import</span> AdapterDateFns <span class="token keyword">from</span> <span class="token string">'@mui/lab/AdapterDateFns'</span><span class="token punctuation">;</span>
<span class="token keyword">import</span> LocalizationProvider <span class="token keyword">from</span> <span class="token string">'@mui/lab/LocalizationProvider'</span><span class="token punctuation">;</span>
<span class="token keyword">function</span> <span class="token function">App</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
<span class="token keyword">return</span> <span class="token punctuation">(</span>
<span class="token tag"><span class="token tag"><span class="token punctuation"><</span><span class="token class-name">LocalizationProvider</span></span> <span class="token attr-name">dateAdapter</span><span class="token script language-javascript"><span class="token script-punctuation punctuation">=</span><span class="token punctuation">{</span>AdapterDateFns<span class="token punctuation">}</span></span><span class="token punctuation">></span></span>
<span class="token operator">...</span>
<span class="token tag"><span class="token tag"><span class="token punctuation"></</span><span class="token class-name">LocalizationProvider</span></span><span class="token punctuation">></span></span>
<span class="token punctuation">)</span>
<span class="token punctuation">)</span><span class="token punctuation">;</span>
Render input
We introduced a new required renderInput
prop. This simplifies using non-Material UI text field input components.
<span class="token tag"><span class="token tag"><span class="token punctuation"><</span><span class="token class-name">DatePicker</span></span> <span class="token attr-name">renderInput</span><span class="token script language-javascript"><span class="token script-punctuation punctuation">=</span><span class="token punctuation">{</span><span class="token punctuation">(</span><span class="token parameter">props</span><span class="token punctuation">)</span> <span class="token operator">=></span> <span class="token tag"><span class="token tag"><span class="token punctuation"><</span><span class="token class-name">TextField</span></span> <span class="token spread"><span class="token punctuation">{</span><span class="token operator">...</span>props<span class="token punctuation">}</span></span> <span class="token punctuation">/></span></span><span class="token punctuation">}</span></span> <span class="token punctuation">/></span></span>
<span class="token tag"><span class="token tag"><span class="token punctuation"><</span><span class="token class-name">TimePicker</span></span> <span class="token attr-name">renderInput</span><span class="token script language-javascript"><span class="token script-punctuation punctuation">=</span><span class="token punctuation">{</span><span class="token punctuation">(</span><span class="token parameter">props</span><span class="token punctuation">)</span> <span class="token operator">=></span> <span class="token tag"><span class="token tag"><span class="token punctuation"><</span><span class="token class-name">TextField</span></span> <span class="token spread"><span class="token punctuation">{</span><span class="token operator">...</span>props<span class="token punctuation">}</span></span> <span class="token punctuation">/></span></span><span class="token punctuation">}</span></span> <span class="token punctuation">/></span></span>
Previously, props were spread on the <TextField />
component. From now on you will need to use the new renderInput
prop to provide these:
<span class="token unchanged"><span class="token prefix unchanged"> </span><span class="token line"><DatePicker
</span></span><span class="token deleted-sign deleted"><span class="token prefix deleted">-</span><span class="token line"> label="Date"
</span><span class="token prefix deleted">-</span><span class="token line"> helperText="Something"
</span></span><span class="token inserted-sign inserted"><span class="token prefix inserted">+</span><span class="token line"> renderInput={props => <TextField label="Date" helperText="Something" /> }
</span></span><span class="token unchanged"><span class="token prefix unchanged"> </span><span class="token line">/></span></span>
State management
The state/value management logic for pickers was rewritten from scratch. Pickers will now call the onChange
prop when each view of the date picker ends is completed. The onError
handler is also completely different. Triple-check your pickers with forms integration, because form-integration issues can be subtle.
No required mask
Mask is no longer required. Also, if your provided mask is not valid, pickers will just ignore the mask, and allow arbitrary input.
<span class="token tag"><span class="token tag"><span class="token punctuation"><</span><span class="token class-name">DatePicker</span></span>
<span class="token attr-name">mask</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">"</span>mm<span class="token punctuation">"</span></span>
<span class="token attr-name">value</span><span class="token script language-javascript"><span class="token script-punctuation punctuation">=</span><span class="token punctuation">{</span><span class="token keyword">new</span> <span class="token class-name">Date</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">}</span></span>
<span class="token attr-name">onChange</span><span class="token script language-javascript"><span class="token script-punctuation punctuation">=</span><span class="token punctuation">{</span>console<span class="token punctuation">.</span>log<span class="token punctuation">}</span></span>
<span class="token attr-name">renderInput</span><span class="token script language-javascript"><span class="token script-punctuation punctuation">=</span><span class="token punctuation">{</span><span class="token punctuation">(</span><span class="token parameter">props</span><span class="token punctuation">)</span> <span class="token operator">=></span> <span class="token punctuation">(</span>
<span class="token tag"><span class="token tag"><span class="token punctuation"><</span><span class="token class-name">TextField</span></span> <span class="token spread"><span class="token punctuation">{</span><span class="token operator">...</span>props<span class="token punctuation">}</span></span> <span class="token attr-name">helperText</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">"</span>invalid mask<span class="token punctuation">"</span></span> <span class="token punctuation">/></span></span>
<span class="token punctuation">)</span><span class="token punctuation">}</span></span>
<span class="token punctuation">/></span></span>
<span class="token tag"><span class="token tag"><span class="token punctuation"><</span><span class="token class-name">DatePicker</span></span>
<span class="token attr-name">value</span><span class="token script language-javascript"><span class="token script-punctuation punctuation">=</span><span class="token punctuation">{</span><span class="token keyword">new</span> <span class="token class-name">Date</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">}</span></span>
<span class="token attr-name">onChange</span><span class="token script language-javascript"><span class="token script-punctuation punctuation">=</span><span class="token punctuation">{</span>console<span class="token punctuation">.</span>log<span class="token punctuation">}</span></span>
<span class="token attr-name">renderInput</span><span class="token script language-javascript"><span class="token script-punctuation punctuation">=</span><span class="token punctuation">{</span><span class="token punctuation">(</span><span class="token parameter">props</span><span class="token punctuation">)</span> <span class="token operator">=></span> <span class="token punctuation">(</span>
<span class="token tag"><span class="token tag"><span class="token punctuation"><</span><span class="token class-name">TextField</span></span> <span class="token spread"><span class="token punctuation">{</span><span class="token operator">...</span>props<span class="token punctuation">}</span></span> <span class="token attr-name">helperText</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">"</span>valid mask<span class="token punctuation">"</span></span> <span class="token punctuation">/></span></span>
<span class="token punctuation">)</span><span class="token punctuation">}</span></span>
<span class="token punctuation">/></span></span>
And many more
<span class="token unchanged"><span class="token prefix unchanged"> </span><span class="token line"><DatePicker
</span></span><span class="token deleted-sign deleted"><span class="token prefix deleted">-</span><span class="token line"> format="DD-MM-YYYY"
</span></span><span class="token inserted-sign inserted"><span class="token prefix inserted">+</span><span class="token line"> inputFormat="DD-MM-YYYY"</span></span>
There are many changes, be careful, make sure your tests, and build passes. In the event you have an advanced usage of the date picker, it will likely be simpler to rewrite it.
Please open a pull request to improve the guide if you notice an opportunity for doing such.