- CSS modules migration - all components are now using CSS modules instead of global CSS classes, this allows us to have better encapsulation and fewer conflicts with other CSS classes.
- Global CSS classnames are no longer exposed, so you can't override or apply them anymore.
data-testid
attributes were added, so you can target components by them instead of global class names.
Version 1 won't receive new features, only critical bug fixes - so if you want to use new features you should migrate to version 2.
Remove overrides of Vibe's global CSS classes (mostly prefixed with monday-style-
). Some of them could be replaced with corresponding className props.
Before:
- .monday-style-button {
- margin-left: var(--spacing-small);
- }
- <Button>Click me</button>
After:
+ .click-me-button {
+ margin-left: var(--spacing-small);
+ }
+ <Button className="click-me-button">Click me</Button>
Before:
- <button className="monday-style-button ...">Click me</button>
After:
+ <Button>Click me</Button>
Fix tests selectors to use data-testid
instead of global CSS classes.
Before:
- document.querySelector('monday-style-button').click();
After:
+ <Button data-testid="my-button"/>
+ document.querySelector(['data-testid="my-button"']).click();
If you use jest snapshot testing, fix jest.config.js
to use moduleNameMapper
for package entry with mocked classnames - so they won't change names during snapshot testing.
+ moduleNameMapper: {
+ "monday-ui-react-core": "monday-ui-react-core/dist/mocked_classnames_esm/src/index.js"
+ }
CommonJS imports for components and hooks from the dist
are going to be deprecated soon, so, please, consider using ESM type of imports.
Before:
- import Button from "monday-ui-react-core/dist/Button";
After:
+ import { Button } from "monday-ui-react-core";