Custom Chakra UI (v2 fork) components for react-querybuilder
npm install @chakra-v2/querybuilderUnofficial react-querybuilder components for Chakra UI v2 fork.
``bash`
npm i react-querybuilder @chakra-v2/querybuilder @chakra-v2/icons @chakra-v2/react @emotion/react @emotion/styled framer-motionOR yarn add / pnpm add / bun add
To render Chakra-compatible components in the query builder, wrap the element in .
`tsx
import { QueryBuilderChakra } from '@chakra-v2/querybuilder';
import { ChakraProvider, extendTheme } from '@chakra-v2/react';
import { QueryBuilder, RuleGroupType } from 'react-querybuilder';
const chakraTheme = extendTheme();
const fields = [
{ name: 'firstName', label: 'First Name' },
{ name: 'lastName', label: 'Last Name' },
];
const App = () => {
const [query, setQuery] = useState
return (
);
};
`
- Some additional styling may be necessary, e.g.:
`css
.queryBuilder .chakra-select__wrapper {
width: fit-content;
display: inline-block;
}
.queryBuilder .chakra-input {
width: auto;
display: inline-block;
}
.queryBuilder .chakra-radio-group {
display: inline-block;
}
`
- This package exports chakraControlElements which can be assigned directly to the controlElements prop on (and also exports each component individually), but this method does not support customized Chakra themes like