@statsig/react-bindings 3.1.0 → 3.2.0-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,9 +1,9 @@
1
1
  {
2
2
  "name": "@statsig/react-bindings",
3
- "version": "3.1.0",
3
+ "version": "3.2.0-beta.1",
4
4
  "dependencies": {
5
- "@statsig/client-core": "3.1.0",
6
- "@statsig/js-client": "3.1.0"
5
+ "@statsig/client-core": "3.2.0-beta.1",
6
+ "@statsig/js-client": "3.2.0-beta.1"
7
7
  },
8
8
  "peerDependencies": {
9
9
  "react": "^16.6.3 || ^17.0.0 || ^18.0.0"
package/src/index.d.ts CHANGED
@@ -9,7 +9,9 @@ import useGateValue from './useGateValue';
9
9
  import useLayer from './useLayer';
10
10
  import useParameterStore from './useParameterStore';
11
11
  import { useStatsigClient } from './useStatsigClient';
12
+ import { useStatsigInternalClientFactoryAsync } from './useStatsigInternalClientFactoryAsync';
13
+ import { useStatsigInternalClientFactoryBootstrap } from './useStatsigInternalClientFactoryBootstrap';
12
14
  import { useStatsigUser } from './useStatsigUser';
13
15
  export type { StatsigProviderProps };
14
16
  export * from '@statsig/js-client';
15
- export { StatsigContext, StatsigProvider, useClientAsyncInit, useClientBootstrapInit, useDynamicConfig, useExperiment, useFeatureGate, useGateValue, useLayer, useParameterStore, useStatsigClient, useStatsigUser, };
17
+ export { StatsigContext, StatsigProvider, useClientAsyncInit, useClientBootstrapInit, useDynamicConfig, useExperiment, useFeatureGate, useGateValue, useLayer, useParameterStore, useStatsigClient, useStatsigInternalClientFactoryAsync, useStatsigInternalClientFactoryBootstrap, useStatsigUser, };
package/src/index.js CHANGED
@@ -14,7 +14,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
14
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
- exports.useStatsigUser = exports.useStatsigClient = exports.useParameterStore = exports.useLayer = exports.useGateValue = exports.useFeatureGate = exports.useExperiment = exports.useDynamicConfig = exports.useClientBootstrapInit = exports.useClientAsyncInit = exports.StatsigProvider = exports.StatsigContext = void 0;
17
+ exports.useStatsigUser = exports.useStatsigInternalClientFactoryBootstrap = exports.useStatsigInternalClientFactoryAsync = exports.useStatsigClient = exports.useParameterStore = exports.useLayer = exports.useGateValue = exports.useFeatureGate = exports.useExperiment = exports.useDynamicConfig = exports.useClientBootstrapInit = exports.useClientAsyncInit = exports.StatsigProvider = exports.StatsigContext = void 0;
18
18
  const StatsigContext_1 = require("./StatsigContext");
19
19
  exports.StatsigContext = StatsigContext_1.default;
20
20
  const StatsigProvider_1 = require("./StatsigProvider");
@@ -37,6 +37,10 @@ const useParameterStore_1 = require("./useParameterStore");
37
37
  exports.useParameterStore = useParameterStore_1.default;
38
38
  const useStatsigClient_1 = require("./useStatsigClient");
39
39
  Object.defineProperty(exports, "useStatsigClient", { enumerable: true, get: function () { return useStatsigClient_1.useStatsigClient; } });
40
+ const useStatsigInternalClientFactoryAsync_1 = require("./useStatsigInternalClientFactoryAsync");
41
+ Object.defineProperty(exports, "useStatsigInternalClientFactoryAsync", { enumerable: true, get: function () { return useStatsigInternalClientFactoryAsync_1.useStatsigInternalClientFactoryAsync; } });
42
+ const useStatsigInternalClientFactoryBootstrap_1 = require("./useStatsigInternalClientFactoryBootstrap");
43
+ Object.defineProperty(exports, "useStatsigInternalClientFactoryBootstrap", { enumerable: true, get: function () { return useStatsigInternalClientFactoryBootstrap_1.useStatsigInternalClientFactoryBootstrap; } });
40
44
  const useStatsigUser_1 = require("./useStatsigUser");
41
45
  Object.defineProperty(exports, "useStatsigUser", { enumerable: true, get: function () { return useStatsigUser_1.useStatsigUser; } });
42
46
  __exportStar(require("@statsig/js-client"), exports);
@@ -51,4 +55,6 @@ __STATSIG__ = Object.assign(Object.assign({}, (__STATSIG__ !== null && __STATSIG
51
55
  useLayer: useLayer_1.default,
52
56
  useParameterStore: useParameterStore_1.default,
53
57
  useStatsigClient: useStatsigClient_1.useStatsigClient,
58
+ useStatsigInternalClientFactoryAsync: useStatsigInternalClientFactoryAsync_1.useStatsigInternalClientFactoryAsync,
59
+ useStatsigInternalClientFactoryBootstrap: useStatsigInternalClientFactoryBootstrap_1.useStatsigInternalClientFactoryBootstrap,
54
60
  useStatsigUser: useStatsigUser_1.useStatsigUser });
@@ -1,19 +1,13 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.useClientAsyncInit = void 0;
4
- const react_1 = require("react");
5
- const client_core_1 = require("@statsig/client-core");
6
4
  const js_client_1 = require("@statsig/js-client");
5
+ const useStatsigInternalClientFactoryAsync_1 = require("./useStatsigInternalClientFactoryAsync");
7
6
  function useClientAsyncInit(sdkKey, initialUser, statsigOptions = null) {
8
- const [isLoading, setIsLoading] = (0, react_1.useState)(true);
9
- const [args] = (0, react_1.useState)(() => {
10
- const client = new js_client_1.StatsigClient(sdkKey, initialUser, statsigOptions);
11
- client
12
- .initializeAsync()
13
- .catch(client_core_1.Log.error)
14
- .finally(() => setIsLoading(false));
15
- return { client, initialUser, sdkKey };
7
+ return (0, useStatsigInternalClientFactoryAsync_1.useStatsigInternalClientFactoryAsync)((args) => new js_client_1.StatsigClient(args.sdkKey, args.initialUser, args.statsigOptions), {
8
+ sdkKey,
9
+ initialUser,
10
+ statsigOptions,
16
11
  });
17
- return { client: args.client, isLoading };
18
12
  }
19
13
  exports.useClientAsyncInit = useClientAsyncInit;
@@ -1,15 +1,14 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.useClientBootstrapInit = void 0;
4
- const react_1 = require("react");
5
4
  const js_client_1 = require("@statsig/js-client");
5
+ const useStatsigInternalClientFactoryBootstrap_1 = require("./useStatsigInternalClientFactoryBootstrap");
6
6
  function useClientBootstrapInit(sdkKey, initialUser, initialValues, statsigOptions = null) {
7
- const [args] = (0, react_1.useState)(() => {
8
- const client = new js_client_1.StatsigClient(sdkKey, initialUser, statsigOptions);
9
- client.dataAdapter.setData(initialValues);
10
- client.initializeSync();
11
- return { client, initialValues, initialUser, sdkKey };
7
+ return (0, useStatsigInternalClientFactoryBootstrap_1.useStatsigInternalClientFactoryBootstrap)((args) => new js_client_1.StatsigClient(args.sdkKey, args.initialUser, args.statsigOptions), {
8
+ sdkKey,
9
+ initialUser,
10
+ initialValues,
11
+ statsigOptions,
12
12
  });
13
- return args.client;
14
13
  }
15
14
  exports.useClientBootstrapInit = useClientBootstrapInit;
@@ -0,0 +1,12 @@
1
+ import { StatsigUser } from '@statsig/client-core';
2
+ import { StatsigClient, StatsigOptions } from '@statsig/js-client';
3
+ type FactoryArgs = {
4
+ sdkKey: string;
5
+ initialUser: StatsigUser;
6
+ statsigOptions: StatsigOptions | null;
7
+ };
8
+ export declare function useStatsigInternalClientFactoryAsync<T extends StatsigClient>(factory: (args: FactoryArgs) => T, args: FactoryArgs): {
9
+ isLoading: boolean;
10
+ client: StatsigClient;
11
+ };
12
+ export {};
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useStatsigInternalClientFactoryAsync = void 0;
4
+ const react_1 = require("react");
5
+ const client_core_1 = require("@statsig/client-core");
6
+ function useStatsigInternalClientFactoryAsync(factory, args) {
7
+ const [isLoading, setIsLoading] = (0, react_1.useState)(true);
8
+ const clientRef = (0, react_1.useRef)(null);
9
+ const client = (0, react_1.useMemo)(() => {
10
+ if (clientRef.current) {
11
+ return clientRef.current;
12
+ }
13
+ const inst = factory(args);
14
+ clientRef.current = inst;
15
+ inst
16
+ .initializeAsync()
17
+ .catch(client_core_1.Log.error)
18
+ .finally(() => setIsLoading(false));
19
+ return inst;
20
+ }, []);
21
+ return { client, isLoading };
22
+ }
23
+ exports.useStatsigInternalClientFactoryAsync = useStatsigInternalClientFactoryAsync;
@@ -0,0 +1,10 @@
1
+ import { StatsigUser } from '@statsig/client-core';
2
+ import { StatsigClient, StatsigOptions } from '@statsig/js-client';
3
+ type FactoryArgs = {
4
+ sdkKey: string;
5
+ initialUser: StatsigUser;
6
+ initialValues: string;
7
+ statsigOptions: StatsigOptions | null;
8
+ };
9
+ export declare function useStatsigInternalClientFactoryBootstrap<T extends StatsigClient>(factory: (args: FactoryArgs) => T, args: FactoryArgs): T;
10
+ export {};
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useStatsigInternalClientFactoryBootstrap = void 0;
4
+ const react_1 = require("react");
5
+ function useStatsigInternalClientFactoryBootstrap(factory, args) {
6
+ const clientRef = (0, react_1.useRef)(null);
7
+ return (0, react_1.useMemo)(() => {
8
+ if (clientRef.current) {
9
+ return clientRef.current;
10
+ }
11
+ const inst = factory(args);
12
+ clientRef.current = inst;
13
+ inst.dataAdapter.setData(args.initialValues);
14
+ inst.initializeSync();
15
+ return inst;
16
+ }, []);
17
+ }
18
+ exports.useStatsigInternalClientFactoryBootstrap = useStatsigInternalClientFactoryBootstrap;