@react-querybuilder/fluent
v8.14.0
Published
Custom Fluent UI components for react-querybuilder
Maintainers
Readme
@react-querybuilder/fluent
Official react-querybuilder compatibility package for Fluent UI.
- Demo
- Full documentation
- CodeSandbox / StackBlitz example projects

Installation
npm i react-querybuilder @react-querybuilder/fluent @fluentui/react-components @fluentui/react-icons-mdl2
# OR yarn add / pnpm add / bun addUsage
To configure the query builder to use Fluent-compatible components, place QueryBuilderFluent above QueryBuilder and beneath FluentProvider in the component hierarchy.
import { FluentProvider, webLightTheme } from '@fluentui/react-components';
import { QueryBuilderFluent } from '@react-querybuilder/fluent';
import { useState } from 'react';
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 (
<FluentProvider theme={webLightTheme}>
<QueryBuilderFluent>
<QueryBuilder fields={fields} defaultQuery={query} onQueryChange={setQuery} />
</QueryBuilderFluent>
</FluentProvider>
);
}QueryBuilderFluent 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 |
| ----------------------- | ------------------------------- |
| fluentControlElements | controlElements |
| fluentTranslations | translations |
| FluentActionElement | controlElements.actionElement |
| FluentDragHandle | controlElements.dragHandle |
| FluentNotToggle | controlElements.notToggle |
| FluentShiftActions | controlElements.shiftActions |
| FluentValueEditor | controlElements.valueEditor |
| FluentValueSelector | controlElements.valueSelector |
[!TIP]
By default, this package uses icons from
@fluentui/react-icons-mdl2for button labels. To reset button labels to their default strings, usedefaultTranslationsfromreact-querybuilder.<QueryBuilderFluent translations={defaultTranslations}>
