-
-
Notifications
You must be signed in to change notification settings - Fork 94
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: Add configuration to getDefaultManagers() (#3161)
- Loading branch information
Showing
27 changed files
with
451 additions
and
138 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
--- | ||
'@data-client/react': patch | ||
'@data-client/core': patch | ||
--- | ||
|
||
Add jsdocs to IdlingNetworkManager |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
--- | ||
'@data-client/react': patch | ||
--- | ||
|
||
Add configuration to [getDefaultManagers()](https://dataclient.io/docs/api/getDefaultManagers) | ||
|
||
```ts | ||
// completely remove DevToolsManager | ||
const managers = getDefaultManagers({ devToolsManager: null }); | ||
``` | ||
|
||
```ts | ||
// easier configuration | ||
const managers = getDefaultManagers({ | ||
devToolsManager: { | ||
// double latency to help with high frequency updates | ||
latency: 1000, | ||
// skip websocket updates as these are too spammy | ||
predicate: (state, action) => | ||
action.type !== actionTypes.SET_TYPE || action.schema !== Ticker, | ||
} | ||
}); | ||
``` | ||
|
||
```ts | ||
// passing instance allows us to use custom classes as well | ||
const managers = getDefaultManagers({ | ||
networkManager: new CustomNetworkManager(), | ||
}); | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,128 @@ | ||
--- | ||
title: getDefaultManagers() - Configuring managers for DataProvider | ||
sidebar_label: getDefaultManagers | ||
--- | ||
|
||
import StackBlitz from '@site/src/components/StackBlitz'; | ||
|
||
# getDefaultManagers() | ||
|
||
`getDefaultManagers` returns an Array of [Managers](./Manager.md) to be sent to [<DataProvider />](./DataProvider.md). | ||
|
||
This makes it simple to configure and add custom [Managers](./Manager.md), while remaining robust against | ||
any potential changes to the default managers. | ||
|
||
Currently returns \[[DevToolsManager](./DevToolsManager.md)\*, [NetworkManager](./NetworkManager.md), [SubscriptionManager](./SubscriptionManager.md)\]. | ||
|
||
\*(`DevToolsManager` is excluded in production builds.) | ||
|
||
## Usage | ||
|
||
```tsx | ||
import { | ||
DevToolsManager, | ||
DataProvider, | ||
getDefaultManagers, | ||
} from '@data-client/react'; | ||
import ReactDOM from 'react-dom'; | ||
|
||
// highlight-start | ||
const managers = getDefaultManagers({ | ||
// set fallback expiry time to an hour | ||
networkManager: { dataExpiryLength: 1000 * 60 * 60 }, | ||
}); | ||
// highlight-end | ||
|
||
ReactDOM.createRoot(document.body).render( | ||
<DataProvider managers={managers}> | ||
<App /> | ||
</DataProvider>, | ||
); | ||
``` | ||
|
||
See [DataProvider](./DataProvider.md) for details on usage in different environments. | ||
|
||
## Arguments | ||
|
||
Each argument represents a configuration of the manager. It can be of three possible types: | ||
|
||
- Any plain object is used as options to be sent to the manager's constructor. | ||
- An instance of the manager to be used directly. | ||
- `null`. When sent will exclude the manager. | ||
|
||
```ts | ||
getDefaultManagers({ | ||
devToolsManager: { trace: true }, | ||
networkManager: new NetworkManager({ errorExpiryLength: 1 }), | ||
subscriptionManager: null, | ||
}); | ||
``` | ||
|
||
### networkManager | ||
|
||
:::note | ||
|
||
`null` is not allowed here since NetworkManager is required | ||
|
||
::: | ||
|
||
`dataExpiryLength` is used as a fallback when an Endpoint does not have [dataExpiryLength](https://dataclient.io/docs/concepts/expiry-policy#endpointdataexpirylength) defined. | ||
|
||
`errorExpiryLength` is used as a fallback when an Endpoint does not have [errorExpiryLength](https://dataclient.io/docs/concepts/expiry-policy#endpointerrorexpirylength) defined. | ||
|
||
### devToolsManager | ||
|
||
[Arguments](https://github.com/reduxjs/redux-devtools/blob/main/extension/docs/API/Arguments.md) | ||
to send to redux devtools. | ||
|
||
### subscriptionManager | ||
|
||
A class that implements `SubscriptionConstructable` like [PollingSubscription](./PollingSubscription.md) | ||
|
||
## Examples | ||
|
||
### Tracing actions | ||
|
||
For example, we can enable the [trace](https://github.com/reduxjs/redux-devtools/blob/main/extension/docs/API/Arguments.md#trace) option to help track down where actions are dispatched from. This has a large performance impact, so it is normally disabled. | ||
|
||
```ts | ||
const managers = getDefaultManagers({ | ||
// highlight-next-line | ||
devToolsManager: { trace: true }, | ||
}); | ||
``` | ||
|
||
### Manager inheritance | ||
|
||
Sending manager instances allows us to customize managers using inheritance. | ||
|
||
```ts | ||
import { IdlingNetworkManager } from '@data-client/react'; | ||
|
||
const managers = getDefaultManagers({ | ||
networkManager: new IdlingNetworkManager(), | ||
}); | ||
``` | ||
|
||
`IdlingNetworkManager` can prevent stuttering by delaying [sideEffect](/rest/api/Endpoint#sideeffect)-free (read-only/GET) fetches | ||
until animations are complete. This works in web using [requestIdleCallback](https://developer.mozilla.org/en-US/docs/Web/API/Window/requestIdleCallback), and react native using InteractionManager.runAfterInteractions. | ||
|
||
### Disabling | ||
|
||
Using `null` will remove managers completely. [NetworkManager](./NetworkManager.md) cannot be removed this way. | ||
|
||
```ts | ||
const managers = getDefaultManagers({ | ||
devToolsManager: null, | ||
subscriptionManager: null, | ||
}); | ||
``` | ||
|
||
Here we disable every manager except [NetworkManager](./NetworkManager.md). | ||
|
||
### Coin App | ||
|
||
New prices are streamed in many times a second; to reduce devtool spam, we set it | ||
to ignore [SET](./Controller.md#set) actions for `Ticker`. | ||
|
||
<StackBlitz app="coin-app" file="src/index.tsx,src/resources/StreamManager.ts,src/getManagers.ts" height="600" /> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
import { getDefaultManagers, actionTypes } from '@data-client/react'; | ||
import StreamManager from 'resources/StreamManager'; | ||
import { Ticker } from 'resources/Ticker'; | ||
|
||
export default function getManagers() { | ||
return [ | ||
new StreamManager( | ||
() => new WebSocket('wss://ws-feed.exchange.coinbase.com'), | ||
{ ticker: Ticker }, | ||
), | ||
...getDefaultManagers({ | ||
devToolsManager: { | ||
// double latency to help with high frequency updates | ||
latency: 1000, | ||
// skip websocket updates as these are too spammy | ||
predicate: (state, action) => | ||
action.type !== actionTypes.SET_TYPE || action.schema !== Ticker, | ||
}, | ||
}), | ||
]; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.