Security News
cURL Project and Go Security Teams Reject CVSS as Broken
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
@harnessio/ff-react-client-sdk
Advanced tools
| ⚠️ ALPHA: PLEASE DON'T USE IN PROD ⚠️ | | ------------------------------------- |
⚠️ ALPHA: PLEASE DON'T USE IN PROD ⚠️ |
---|
Use this README to get started with our Feature Flags (FF) Client SDK for React.js. This guide outlines the basics of getting started with the SDK and provides a full code sample for you to try out.
This sample doesn't include configuration options, for in depth steps and configuring the SDK, see the JavaScript Client SDK Reference.
To use this SDK, make sure you’ve:
To follow along with our test code sample, make sure you’ve:
harnessappdemodarkmode
The first step is to install the FF SDK as a dependency in your application. To install using npm, use:
npm install @harnessio/ff-react-client-sdk
Or to install with yarn, use:
yarn add @harnessio/ff-react-client-sdk
The following is a complete code example that you can use to test the harnessappdemodarkmode
Flag you created on the
Harness Platform. When you run the code it will:
useFeatureFlag
hookuseFeatureFlags
hookimport React from 'react'
import ReactDOM from 'react-dom'
import {
FFContextProvider,
useFeatureFlag,
useFeatureFlags
} from '@harnessio/ff-react-client-sdk'
ReactDOM.render(<App />, document.querySelector('#react-root'))
function App() {
return (
<FFContextProvider
apiKey="YOUR_API_KEY"
target={{
identifier: 'reactclientsdk',
name: 'ReactClientSDK'
}}
>
<SingleFeatureFlag />
<MultipleFeatureFlags />
</FFContextProvider>
)
}
function SingleFeatureFlag() {
const flagValue = useFeatureFlag('harnessappdemodarkmode')
return (
<p>The value of "harnessappdemodarkmode" is {JSON.stringify(flagValue)}</p>
)
}
function MultipleFeatureFlags() {
const flags = useFeatureFlags()
return (
<>
<p>Here are all our flags:</p>
<pre>{JSON.stringify(flags, null, 2)}</pre>
</>
)
}
By default, the React Client SDK will block rendering of children until the initial load of Feature Flags has completed.
This ensures that children have immediate access to all Flags when they are rendered. However, in some circumstances it
may be beneficial to immediately render the application and handle display of loading on a component-by-component basis.
The React Client SDK's asynchronous mode allows this by passing the optional async
prop when connecting with the
FFContextProvider
.
FFContextProvider
The FFContextProvider
component is used to set up the React context to allow your application to access Feature Flags
using the useFeatureFlag
and useFeatureFlags
hooks and withFeatureFlags
HOC. At minimum, it requires the apiKey
you have set up in
your Harness Feature Flags account, and the target
. You can think of a target
as a user.
The FFContextProvider
component also accepts an options
object, a fallback
component and can be placed in
Async mode using the async
prop. The fallback
component will be displayed while the SDK is connecting
and fetching your flags.
import { FFContextProvider } from '@harnessio/ff-react-client-sdk'
// ...
function MyComponent() {
return (
<FFContextProvider
async={false} // OPTIONAL: whether or not to use async mode
apiKey="YOUR_API_KEY" // your SDK API key
target={{
identifier: 'targetId', // unique ID of the Target
name: 'Target Name', // name of the Target
attributes: { // OPTIONAL: key/value pairs of attributes of the Target
customAttribute: 'this is a custom attribute',
anotherCustomAttribute: 'this is something else'
}
}}
fallback={<p>Loading ...</p>} // OPTIONAL: component to display when the SDK is connecting
options={{ // OPTIONAL: advanced options
baseUrl: 'https://url-to-access-flags.com',
eventUrl: 'https://url-for-events.com',
streamEnabled: true,
allAttributesPrivate: false,
privateAttributeNames: ['customAttribute'],
debug: true
}}
>
<CompontToDisplayAfterLoad /> <!-- component to display when Flags are available -->
< /FFContextProvider>
)
}
useFeatureFlag
The useFeatureFlag
hook returns a single named flag value. An optional second argument allows you to set what value
will be returned if the flag does not have a value. By default useFeatureFlag
will return undefined
if the flag
cannot be found.
N.B. when rendered in Async mode, the default value will be returned until the Flags are retrieved.
import { useFeatureFlag } from '@harnessio/ff-react-client-sdk'
// ...
function MyComponent() {
const myFlagValue = useFeatureFlag('flagIdentifier', 'default value')
return <p>My flag value is: {myFlagValue}</p>
}
useFeatureFlags
The useFeatureFlags
hooks returns an object of Flag identifier/Flag value pairs. You can pass an array of Flag
identifiers or an object of Flag identifier/default value pairs. If an array is used and a Flag cannot be found, the
returned value for the flag will be undefined
. If no arguments are passed, all Flags will be returned.
N.B. when rendered in Async mode, the default value will be returned until the Flags are retrieved.
import { useFeatureFlag } from '@harnessio/ff-react-client-sdk'
// ...
function MyComponent() {
const myFlagValues = useFeatureFlags()
return (
<>
<p>My flag values are:</p>
<pre>{JSON.stringify(myFlagValues, null, 2)}</pre>
</>
)
}
const myFlagValues = useFeatureFlags(['flag1', 'flag2'])
const myFlagValues = useFeatureFlags({
flag1: 'defaultForFlag1',
flag2: 'defaultForFlag2'
})
ifFeatureFlag
The ifFeatureFlag
higher-order component (HOC) wraps your component and conditionally renders only when the named flag
is enabled or matches a specific value.
import { ifFeatureFlag } from '@harnessio/ff-react-client-sdk'
// ...
function MyComponent() {
return <p>This should render if the flag is on</p>
}
const MyConditionalComponent = ifFeatureFlag('flag1')(MyComponent)
You can then use MyConditionalComponent
as a normal component, and only render if flag1
's value is truthy.
import { ifFeatureFlag } from '@harnessio/ff-react-client-sdk'
// ...
function MyComponent() {
return <p>This should render if the flag evaluates to 'ABC123'</p>
}
const MyConditionalComponent = ifFeatureFlag('flag1', { matchValue: 'ABC123' })(
MyComponent
)
You can then use MyConditionalComponent
as a normal component, only render if flag1
's value matches the passed
condition.
If Async mode is used, by default the component will wait for Flags to be retrieved before showing. This
behaviour can be overridden by passing an element as loadingFallback
; when loading the loadingFallback
will be
displayed until the Flags are retrieved, at which point the component will either show or hide as normal.
import { ifFeatureFlag } from '@harnessio/ff-react-client-sdk'
// ...
function MyComponent() {
return <p>This should render if the flag is on</p>
}
const MyConditionalComponent = ifFeatureFlag('flag1', {
loadingFallback: <p>Loading...</p>
})(MyComponent)
withFeatureFlags
The withFeatureFlags
higher-order component (HOC) wraps your component and adds flags
and loading
as additional
props. flags
contains the evaluations for all known flags and loading
indicates whether the SDK is actively fetching
Flags.
import { withFeatureFlags } from '@harnessio/ff-react-client-sdk'
// ...
function MyComponent({ flags }) {
return <p>Flag1's value is {flags.flag1}</p>
}
const MyComponentWithFlags = withFeatureFlags(MyComponent)
If Async mode is used, the loading
prop will indicate whether the SDK has completed loading the Flags.
When loading completes, the loading
prop will be false
and the flags
prop will contain all known Flags.
import { withFeatureFlags } from '@harnessio/ff-react-client-sdk'
// ...
function MyComponent({ flags, loading }) {
if (loading) {
return <p>Loading...</p>
}
return <p>Flag1's value is {flags.flag1}</p>
}
const MyComponentWithFlags = withFeatureFlags(MyComponent)
For further examples and config options, see the React.js Client SDK Reference and the test React.js project. For more information about Feature Flags, see our Feature Flags documentation.
FAQs
[![React version][react-badge]][reactjs] [![TypeScript version][ts-badge]][typescript-4-7] [![Node.js version][nodejs-badge]][nodejs] [![APLv2][license-badge]][license]
The npm package @harnessio/ff-react-client-sdk receives a total of 4,753 weekly downloads. As such, @harnessio/ff-react-client-sdk popularity was classified as popular.
We found that @harnessio/ff-react-client-sdk demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Security News
Biden's executive order pushes for AI-driven cybersecurity, software supply chain transparency, and stronger protections for federal and open source systems.