-
Notifications
You must be signed in to change notification settings - Fork 2.2k
Blueprint 4.0
Adi Dahiya edited this page Apr 26, 2021
·
38 revisions
Blueprint 4.0 is planned for release in April 2021. It will include fixes and improvements to the JS APIs and only minor changes to styles / CSS APIs. We are aiming to make the upgrade as smooth as possible, avoiding the kinds of conflicts which made the v1 → v3 transition difficult. Larger systemic changes to the design system may be targeted for Blueprint 5.x.
To prepare for the 4.0 release, you should check out the Migration guides linked in the wiki sidebar →
- Full compatibility with React strict mode
- Use Popper.js 2.0 (#4023)
- No more decorator APIs, just components/hooks instead (#3604)
-
@HotkeysTarget
-><HotkeysTarget>
/useHotkeys
-
@ContextMenuTarget
-><ContextMenuTarget>
-
- Icons split into separate modules to allow tree-shaking and/or lazy-loading only the icons you use (#2193)
- React 16.8+ required
- CSS namespace changed from
bp3-
tobp4-
- TypeScript interfaces renamed to drop their
I
prefix (reasons listed here)- Blueprint versions released on 2021-04-19 (core v3.44.0, datetime 3.23.0, popover2 0.6.0, select 3.16.0, timezone 3.9.0) and newer contain type aliases for most interface names in the public API without the
I
prefix, so you may migrate to these symbols in v3.x before going to v4.0 directly.
- Blueprint versions released on 2021-04-19 (core v3.44.0, datetime 3.23.0, popover2 0.6.0, select 3.16.0, timezone 3.9.0) and newer contain type aliases for most interface names in the public API without the
- Improved
<PanelStack>
component API (parameterized by its panel data type) (#4272) - Simpler, more straightforward React ref APIs.
elementRef
prop has been replaced by the simpler, more straightforwardref
prop usingReact.forwardRef()
(see docs). This applies to:- Typography HTML components (
H1
,H2
, ...Code
,Label
, etc.) -
HTMLSelect
,HTMLTable
, andTag
(these components are also now function components instead of class components, which is a slight break)
- Typography HTML components (
- TypeScript consumers will need to enable
allowSyntheticDefaultImports
to compile Blueprint library typings
-
<CollapsibleList>
is removed (deprecated since 3.0.0)- Use
<OverflowList>
instead.
- Use
-
Classes.SELECT
is removed (deprecated since 3.0.0)- Use
<HTMLSelect>
orClasses.HTML_SELECT
instead.
- Use
-
IKeyWhitelist
andIKeyBlacklist
are removed (deprecated since 3.30.0)- Use
KeyAllowlist
/KeyDenylist
instead.
- Use
-
Utils.safeInvoke
andUtils.safeInvokeOrValue
are removed (deprecated since 3.32.0)- Use TypeScript optional call operator
?.()
instead (available since TS 3.7).
- Use TypeScript optional call operator
-
Utils.createReactRef
andIElementRefProps
are removed (deprecated since 3.43.0)- Use
ref
prop name andReact.createRef
,React.useRef
,React.forwardRef()
instead
- Use
-
IDrawerProps.vertical
is removed (deprecated since 3.15.0)- Use the
position
prop on<Drawer>
instead.
- Use the
-
<HTMLTable>
componentsmall
prop is removed (deprecated since 3.6.0)- Use the
condensed
prop instead.
- Use the
-
AbstractComponent
andAbstractPureComponent
are replaced by their “v2” counterparts (deprecated since 3.19.0)- The new implementations no longer use deprecated React lifecycle methods.
-
IControlledProps2
is nowControlledProps
(deprecated since 3.37.0)- compared to
IControlledProps
:-
onChange
is removed. We recommend unioning the type with (for example)Pick<React.InputHTMLAttributes<HTMLInputElement>, "onChange">
to achieve the same outcome.
-
- compared to
-
Menu.Item
andMenu.Divider
are removed (deprecated since 3.38.0, see #3829)- Use
MenuItem
andMenuDivider
instead.
- Use
-
IConstructor
is removed (deprecated since 3.43.0) -
createReactRef
is removed in favor of React APIs (deprecated since 3.43.0) -
getDisplayName
is removed (deprecated since 3.43.0) -
LifecycleCompatPolyfill
type is removed (deprecated since 3.43.0)
-
<ResizeSensor>
now supports React strict mode, but this means it must be stricter about its children, see ResizeSensor 4.0 changes -
<Portal>
has switched to use the stable React context API instead of the legacy API. See Portal 4.0 changes -
<Popover popoverRef>
prop now supports ref objects, not just ref callbacks -
ButtonProps
/AnchorButtonProps
now include HTML attributes for buttons, so you may create reusable components which render<Button>
/<AnchorButton>
and expose this props type (you no longer have to type union withReact.HTMLAttributes
, etc.)
- CSS Modules (#248)
- Will aim for 5.x release to support custom theming
- Removal of icon fonts
- This was initially planned for 4.x and we started deprecating the icon fonts in Fall 2020. But it looks like we can continue supporting them with minimal visual breaks and maintenance cost by using the right tooling, such as this icon font generation library.
- react-day-picker v8 migration
- HotkeysTarget & useHotkeys migration
- PanelStack2 migration
- Table 6.0 changes