Querity React Components is a set of React components designed to simplify the creation of user interfaces for querying data from Java backends using the Querity library.
Querity is a Java query builder that enables developers to construct complex queries using a simple query language or a fluent Java API. It supports various data sources, including both SQL and NoSQL databases.
This component library is built with TypeScript and aims to keep peer dependencies to a minimum, ensuring a lightweight and flexible integration.
Check out the simplest demo application using Querity at querity-demo.
- React 19
You can install the package using npm or yarn:
npm install @queritylib/react
or
yarn add @queritylib/react
To use the Querity components, you need to wrap your application with the QuerityComponentsProvider
. This provider is responsible for providing the HTML components and the CSS styles needed for the Querity components to function properly.
You can override the default components and styles by passing custom components and styles to the provider.
This allows you to use any CSS framework or custom styles you prefer, such as Tailwind CSS, MUI, Bootstrap, or any other CSS-in-JS solution.
Wrap your application with the QuerityComponentsProvider
and use the default components:
import {
QuerityComponentsProvider,
defaultQuerityComponents,
QuerityField,
QuerityBuilderUI
} from "@queritylib/react";
function App() {
return (
<QuerityComponentsProvider value={...defaultQuerityComponents}>
<QuerityField />
<QuerityBuilderUI />
</QuerityComponentsProvider>
);
}
And import the default theme CSS file:
@import '@queritylib/react/themes/default/style.css';
Don't import the default theme CSS file, but instead use your own CSS framework or custom styles.
import {
QuerityComponentsProvider,
defaultQuerityComponents,
QuerityField,
QuerityBuilderUI
} from "@queritylib/react";
const querityComponents: ComponentOverrides = {
...defaultQuerityComponents,
Input: (props) => <input {...props} className={`${props.className} border p-2`} />,
Select: (props) => <select {...props} className={`${props.className} border p-2`} />,
Button: (props) => <button {...props} className={`${props.className} bg-gray-200 p-2 cursor-pointer`} />,
Checkbox: (props) => (
<label className="inline-flex items-center cursor-pointer">
<input type="checkbox" {...props} className="sr-only peer" />
<div
className="relative w-11 h-6 bg-gray-200 peer-focus:outline-none peer-focus:ring-4 peer-focus:ring-blue-300 dark:peer-focus:ring-blue-800 rounded-full peer dark:bg-gray-700 peer-checked:after:translate-x-full rtl:peer-checked:after:-translate-x-full peer-checked:after:border-white after:content-[''] after:absolute after:top-[2px] after:start-[2px] after:bg-white after:border-gray-300 after:border after:rounded-full after:h-5 after:w-5 after:transition-all dark:border-gray-600 peer-checked:bg-blue-600 dark:peer-checked:bg-blue-600"></div>
<span className="ms-3 text-sm font-medium text-gray-900 dark:text-gray-300">{props.label}</span>
</label>
)
};
function App() {
return (
<QuerityComponentsProvider value={querityComponents}>
<QuerityField />
<QuerityBuilderUI />
</QuerityComponentsProvider>
);
}
See src/themes/default/style.css
as an example of how to style the default components.
QuerityField
is a text input component designed for entering and validating queries. It includes built-in validation, event handling, and customizable styling.
The invalid state can be styled by detecting the aria-invalid
attribute.
Here's how it looks (with custom styles, see Provider & Styling):
import { QuerityField } from "@queritylib/react";
<QuerityField
value="" // Optional: Default query value
placeholder="Enter query" // Optional: Placeholder text
className="custom-class" // Optional: Custom CSS class
onChange={(value) => console.log(value)} // Optional: Handle query input change
onEnter={(value) => console.log(value)} // Optional: Handle Enter key press
onInvalidQuery={(error) => console.log(error)} // Optional: Handle invalid queries
/>
To apply a style when state is invalid add this CSS to your stylesheet:
.querity-field[aria-invalid="true"] {
border-color: red;
}
Prop | Type | Description | Default |
---|---|---|---|
value |
string |
Initial query value | "" |
placeholder |
string |
Input placeholder text | "" |
className |
string |
Additional CSS classes | "" |
onChange |
(value: string) => void |
Called when the query input changes | - |
onEnter |
(value: string) => void |
Called when the user presses Enter | - |
onInvalidQuery |
(error: string) => void |
Called when an invalid query is entered | - |
QuerityBuilderUI
is a component that provides a user interface for building queries.
It includes all the necessary components to create a query in a visual way, including filters, sorting, and pagination.
Here's how it looks (with default theme, see Provider & Styling):
import { QuerityBuilderUI } from "@queritylib/react";
<QuerityBuilderUI
query={query}
onChange={(q) => console.log('Query updated', q)}
className="custom-class"
/>
Prop | Type | Description | Default |
---|---|---|---|
query |
QuerityQuery |
Initial query object | - |
onChange |
(query: string) => void |
Called when the query is updated | - |
className |
string |
Additional CSS classes | - |
QuerityParser
is a utility for parsing and validating the Querity query language. It provides methods to check the validity of a query and to parse it into a structured format.
import { QuerityParser } from "@queritylib/react";
try {
const input = 'lastName="Skywalker" sort by firstName page 1,10'
const query = QuerityParser.parseQuery(input)
console.log(query)
/*
{
filter: {
propertyName: "lastName",
operator: Operator.EQUALS,
value: "Skywalker"
},
sort: [{
propertyName: "firstName",
direction: Direction.ASC
}],
pagination: {
page: 1,
size: 10
},
distinct: false
}
*/
} catch (e) {
console.log('Query parsing error', e)
}
QuerityBuilder
is a utility for building query string from a structured format. It provides methods to convert a query object into a string representation.
import { QuerityBuilder, Query, Operator } from "@queritylib/react";
const queryObj: Query = {
filter: { propertyName: "lastName", operator: Operator.EQUALS, value: "Skywalker" }
}
const queryStr = QuerityBuilder.buildQuery(queryObj)
console.log(queryStr)
// lastName="Skywalker"
To make changes to the components in this library and test them in a real application, we strongly suggest to use
npm link
to link the library to your local environment and use it into the Querity Demo frontend.
To do this, follow these steps:
npm link # in the library directory
npm link @queritylib/react # in the Querity Demo frontend directory
We welcome contributions! If you’d like to improve this library, feel free to submit a pull request or open an issue.
This project is licensed under the Apache-2.0 License. See the LICENSE file for details.
For any questions or feedback, please reach out via the GitHub repository.