title | description | releaseUrl | releaseDate | version |
---|---|---|---|---|
Version 2.4.2 |
Explore the changelog for Chakra UI version 2.4.2. Learn about the latest features, bug fixes, and improvements. |
November 29, 2022 |
2.4.2 |
-
Add
ChakraBaseProvider
, a minimal version ofChakraProvider
that supplies just the theme tokens, and ignores components.Historically, one of the biggest causes of the large initial JS payload is the size of the component themes. With this approach, you get to apply the theme for just the component you need by using
extendBaseTheme
.Base theme refers to the minimal theme for just the design tokens
import { ChakraBaseProvider, extendBaseTheme } from "@chakra-ui/react" import { Button } from "@chakra-ui/theme/components" const theme = extendBaseTheme({ components: { Button, }, }) function App() { return ( <ChakraBaseProvider theme={theme}> <Component {...pageProps} /> </ChakraBaseProvider> ) }
- Add support for
textIndent
style prop
-
Add the flag
--strict-token-types
for@chakra-ui/cli tokens
to generate strict types for theme tokens (e.g. color, spacing)chakra-cli tokens --strict-token-types
// before <Box padding="abc" /> // valid type, but "abc" is not available in the theme // after <Box padding="abc" /> // invalid // Type '"abc"' is not assignable to type '"1" | "2" | ... | undefined'.
-
Added support for setting the initially focused menu programmatically using
initialFocusRef
.const Example = () => { const itemRef = useRef(null) return ( <Menu initialFocusRef={itemRef}> <MenuButton>Welcome</MenuButton> <MenuList> <MenuItem>Menu 1</MenuItem> <MenuItem ref={itemRef}>Menu 2</MenuItem> <MenuItem>Menu 3</MenuItem> </MenuList> </Menu> ) }
-
Added support for
orientation
prop in the ButtonGroup component.This makes it possible to now have vertical button groups when
isAttached
is set totrue
.<ButtonGroup isAttached orientation="vertical"> <Button>Button 1</Button> <Button>Button 2</Button> <Button>Button 3</Button> <Button>Button 4</Button> </ButtonGroup>
-
Added support for styling the
Icon
component from the theme object.const theme = extendTheme({ components: { Icon: { width: "auto", }, }, })
- Updated type of
value
anddefaultValue
tostring
instead ofstring | number
. This reflects the internal implementation
- Expose
SliderActions
andSliderState
types to improve documentation
- Fix issue where modal dialog scrolls beyond the content in Safari.
- Fixed css variabled warning with
Tabs
when using the enclosed variant. - Export
baseTheme
object with includes only the theme tokens.
- Replaced
tinycolor
package withcolor2k
for smaller bundle size
- Fixed issue where types were not exported correctly
- Fix peer dependency range to support latest version of Gatsby