@chakra-v2/querybuilder
v6.6.0
Published
Custom Chakra UI (v2 fork) components for react-querybuilder
Readme
@chakra-v2/querybuilder
Unofficial react-querybuilder components for Chakra UI v2 fork.
Installation
npm i react-querybuilder @chakra-v2/querybuilder @chakra-v2/icons @chakra-v2/react @emotion/react @emotion/styled framer-motion
# OR yarn add / pnpm add / bun addUsage
To render Chakra-compatible components in the query builder, wrap the <QueryBuilder /> element in <QueryBuilderChakra />.
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<RuleGroupType>({ combinator: 'and', rules: [] });
return (
<ChakraProvider theme={chakraTheme}>
<QueryBuilderChakra>
<QueryBuilder fields={fields} query={query} onQueryChange={q => setQuery(q)} />
</QueryBuilderChakra>
</ChakraProvider>
);
};Notes
Some additional styling may be necessary, e.g.:
.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
chakraControlElementswhich can be assigned directly to thecontrolElementsprop on<QueryBuilder />(and also exports each component individually), but this method does not support customized Chakra themes like<QueryBuilderChakra />.
