SDK-Redux is an application framework for building front-end applications that interact with the StreamPay Protocol.
More specifically, SDK-Redux is a wrapper library around @streamable-finance/sdk-core
which adds state management to StreamPay related queries and operations.
Under the hood, SDK-Redux leverages popular Redux libraries Redux Toolkit & RTK Query.
SDK-Redux is in early active development and can have breaking releases without warning and without consideration for semantic versioning.
- Tracking loading state in order to show UI spinners
- Avoiding duplicate requests for the same data
- Managing cache lifetimes as the user interacts with the UI
- Tracking blockchain transactions produced by user interactions
- TypeScript
- Redux
- Redux Toolkit
- RTK Query
- Ethers
- SDK-Core
- Redux store & Redux Toolkit
- React* (The SDK-Redux generates React Hooks which are recommended but not strictly necessary to use. The SDK-Redux is UI-framework agnostic but we currently have example only for React)
Requirements:
A brand-new scaffolded Redux store configuration looks something like this:
import { configureStore, ThunkAction, Action } from '@reduxjs/toolkit';
export const store = configureStore({
reducer: {
},
});
export type AppDispatch = typeof store.dispatch;
export type RootState = ReturnType<typeof store.getState>;
export type AppThunk<ReturnType = void> = ThunkAction<
ReturnType,
RootState,
unknown,
Action<string>
>;
We need to plug in the StreamPay SDK-Redux parts.
Import the following function:
import {
allSubgraphSliceEndpoints,
createApiWithReactHooks,
initializeSfApiSlice,
initializeSfSubgraphSlice,
initializeSfTransactionSlice
} from "@streamable-finance/sdk-redux";
Create the Redux slices:
export const { sfApi } = initializeSfApiSlice(createApiWithReactHooks);
export const { sfTransactions } = initializeSfTransactionSlice();
export const sfSubgraph = initializeSfSubgraphSlice(createApiWithReactHooks).injectEndpoints(allSubgraphSliceEndpoints);
Plug in the slices to the Redux store:
export const store = configureStore({
reducer: {
"sfApi": sfApi.reducer,
"sfTransactions": sfTransactions.reducer,
"sfSubgraph": sfSubgraph.reducer
}
});
Add the middleware:
export const store = configureStore({
reducer: {
"sfApi": sfApi.reducer,
"sfTransactions": sfTransactions.reducer,
},
middleware: (getDefaultMiddleware) =>
getDefaultMiddleware().concat(sfApi.middleware).concat(sfSubgraph.middleware),
});
Somewhere in your code, give instructions to the superfluidContext
to locate Framework
and Signer
:
import { setFrameworkForSdkRedux, setSignerForSdkRedux } from "@streamable-finance/sdk-redux";
setFrameworkForSdkRedux(chainId, sdkCoreFramework);
setSignerForSdkRedux(chainId, ethersWeb3Provider.getSigner());
That should be it! You should now be able to dispatch messages to StreamPay reducers & use the React hooks.
Read about RTK-Query queries here: https://redux-toolkit.js.org/rtk-query/usage/queries
Example using React Hook:
const {
data: pagedStreams,
isUninitialized,
isFetching,
isLoading,
isError,
error,
refetch,
} = sfSubgraph.useStreamsQuery({
chainId: queryChainId,
filter: {
token: superTokenAddress,
sender: senderAddress
},
pagination: {
skip: (page - 1) * pageSize,
take: pageSize
},
ordering: {
orderBy: "currentFlowRate",
orderDirection: "desc"
}
}, {
pollingInterval: 5000 // Not necessary to use but nice-to-have additional option by RTK-Query.
});
Read about RTK-Query queries here: https://redux-toolkit.js.org/rtk-query/usage/mutations
Example using React Hook:
const tx = await sfApi.createFlow({
senderAddress: signerAddress,
receiverAddress: receiver,
flowRateWei: flowRate,
chainId,
superTokenAddress: superToken,
waitForConfirmation,
}).unwrap();
All mutations trigger tracking for transaction progress (stored in transactionSlice
) and transaction monitoring for re-orgs (all cached data is re-fetched in case of a re-org).