A library of ready-to-use React components connected to the Monite API. These components display the data served from the Monite API and also provide data editing functionality.
Note: This package is part of a monorepo. See the main README for more information.
- Node.js 16 or later.
- At least 8 GB RAM on each development workstation.
- A partner account registered with Monite. For details, see Get started with Monite API.
Monite UI Widgets support the five latest versions of major browsers: Chrome, Firefox, Safari, Edge, Opera.
npm install @monite/sdk-react
or
yarn add @monite/sdk-react
Before using Monite UI Widgets, complete the Getting started guide to set up your partner account and get API the credentials.
We also assume you have already mapped out your customers and their users as entities and entity users in Monite, and that you have the ability to:
- look up the Monite entity user ID for the user who is logged in to your application;
- look up the Monite entity ID to which the user belongs.
When an entity user logs in to your application, look up the entity ID and user ID for that user, and call Monite's POST /auth/token
endpoint to generate a Monite access token for that user.
Once you have a user access token and an entity ID, you can initialize the Monite client and widgets, as shown.
The following example renders a table that displays an entity's counterparts:
import { MoniteSDK } from "@monite/sdk-api";
import {
MoniteProvider,
CounterpartsTable,
} from "@monite/sdk-react";
function App() {
const fetchToken = async () => {
const response = await fetch(
"https://api.sandbox.monite.com/v1/auth/token",
{
method: "POST",
headers: {
"Content-Type": "application/json",
"x-monite-version": "2023-06-04", //Monite API version
},
body: JSON.stringify({
grant_type: "entity_user",
entity_user_id: "ENTITY_USER_ID",
client_id: "CLIENT_ID",
client_secret: "CLIENT_SECRET",
}),
}
);
return response.json();
};
const monite = new MoniteSDK({
apiUrl: "https://api.sandbox.monite.com/v1", // '<https://api.monite.com/v1>' if in Production
entityId: "ENTITY_ID",
fetchToken,
});
return (
<MoniteProvider monite={monite} locale={{ code: "de-DE" }}>
<div className="App">
<CounterpartsTable />
</div>
</MoniteProvider>
);
}
export default App;
The MoniteProvider
element serves as a wrapper for other Monite-connected components.
Any other components imported from @monite/sdk-react
must be placed inside this element.
To use our SDK React in Jest tests, you need to modify your Jest configuration to include our polyfill. This ensures that the SDK functionalities are appropriately initialized and available during testing.
Include the following in your Jest configuration file, typically jest.config.js
or jest.config.json
, to ensure proper setup for SDK testing:
{
// ... (other configuration settings)
setupFiles: ['@monite/sdk-react/setup-tests.cjs'],
}
The setupFiles
array includes our SDK polyfill (@monite/sdk-react/setup-tests.cjs
), which needs to be executed before the tests.
This polyfill checks if the TextEncoder
and crypto.subtle
are available globally. If not, it provides them using Node.js modules.
MIT