UNPKG

@react-querybuilder/tremor

Version:

Custom Tremor components for react-querybuilder

54 lines (40 loc) 2.17 kB
## @react-querybuilder/tremor Official [react-querybuilder](https://npmjs.com/package/react-querybuilder) compatibility package for [Tremor](https://www.tremor.so/). - [Demo](https://react-querybuilder.js.org/demo/tremor) - [Full documentation](https://react-querybuilder.js.org/) - [CodeSandbox](https://react-querybuilder.js.org/sandbox?t=tremor) / [StackBlitz](https://react-querybuilder.js.org/sandbox?p=stackblitz&t=tremor) example projects ![Screenshot](../../_assets/screenshot-tremor.png) ## Installation ```bash npm i react-querybuilder @react-querybuilder/tremor @tremor/react # OR yarn add / pnpm add / bun add ``` ## Usage To configure the query builder to use Tremor-compatible components, place `QueryBuilderTremor` above `QueryBuilder` in the component hierarchy. ```tsx import { useState } from 'react'; import { QueryBuilderTremor } from '@react-querybuilder/tremor'; import { type Field, QueryBuilder, type RuleGroupType } from 'react-querybuilder'; const fields: Field[] = [ { name: 'firstName', label: 'First Name' }, { name: 'lastName', label: 'Last Name' }, ]; export function App() { const [query, setQuery] = useState<RuleGroupType>({ combinator: 'and', rules: [] }); return ( <QueryBuilderTremor> <QueryBuilder fields={fields} defaultQuery={query} onQueryChange={setQuery} /> </QueryBuilderTremor> ); } ``` `QueryBuilderTremor` is a React context provider that assigns the following props to all descendant `QueryBuilder` elements. The props can be overridden on the `QueryBuilder` or used directly without the context provider. | Export | `QueryBuilder` prop | | ------------------------- | ------------------------------- | | `tremorControlElements` | `controlElements` | | `tremorControlClassnames` | `controlClassnames` | | `TremorActionElement` | `controlElements.actionElement` | | `TremorNotToggle` | `controlElements.notToggle` | | `TremorShiftActions` | `controlElements.shiftActions` | | `TremorValueEditor` | `controlElements.valueEditor` | | `TremorValueSelector` | `controlElements.valueSelector` |