@statsig/react-native-bindings 0.0.1-beta.16 → 0.0.1-beta.18
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 +4 -5
- package/src/StatsigMetadataAdditions.d.ts +1 -1
- package/src/StatsigMetadataAdditions.js +14 -10
- package/src/index.d.ts +6 -4
- package/src/index.js +9 -18
- package/src/AsyncStorageWarming.d.ts +0 -5
- package/src/AsyncStorageWarming.js +0 -39
- package/src/StatsigProviderRN.d.ts +0 -7
- package/src/StatsigProviderRN.js +0 -29
package/package.json
CHANGED
|
@@ -1,14 +1,13 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@statsig/react-native-bindings",
|
|
3
|
-
"version": "0.0.1-beta.
|
|
3
|
+
"version": "0.0.1-beta.18",
|
|
4
4
|
"dependencies": {
|
|
5
|
-
"@statsig/client-core": "0.0.1-beta.
|
|
6
|
-
"@statsig/react-bindings": "0.0.1-beta.
|
|
5
|
+
"@statsig/client-core": "0.0.1-beta.18",
|
|
6
|
+
"@statsig/react-bindings": "0.0.1-beta.18",
|
|
7
|
+
"@statsig/react-native-core": "0.0.1-beta.17"
|
|
7
8
|
},
|
|
8
9
|
"peerDependencies": {
|
|
9
|
-
"react": "^16.6.3 || ^17.0.0 || ^18.0.0",
|
|
10
10
|
"react-native": "0.*",
|
|
11
|
-
"@react-native-async-storage/async-storage": "1.*",
|
|
12
11
|
"react-native-device-info": "10.*"
|
|
13
12
|
},
|
|
14
13
|
"type": "commonjs",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export
|
|
1
|
+
export declare function GetStatsigMetadataAdditions(): Record<string, string | undefined>;
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var _a, _b, _c, _d
|
|
2
|
+
var _a, _b, _c, _d;
|
|
3
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.GetStatsigMetadataAdditions = void 0;
|
|
4
5
|
const react_native_1 = require("react-native");
|
|
5
6
|
const react_native_device_info_1 = require("react-native-device-info");
|
|
6
|
-
const client_core_1 = require("@statsig/client-core");
|
|
7
7
|
let locale = undefined;
|
|
8
8
|
if (react_native_1.Platform.OS === 'android') {
|
|
9
9
|
const i18nManager = react_native_1.NativeModules['I18nManager'];
|
|
@@ -14,11 +14,15 @@ if (react_native_1.Platform.OS === 'ios') {
|
|
|
14
14
|
const settings = settingsManager === null || settingsManager === void 0 ? void 0 : settingsManager.settings;
|
|
15
15
|
locale = (_d = (_b = settings === null || settings === void 0 ? void 0 : settings.AppLocale) !== null && _b !== void 0 ? _b : (_c = settings === null || settings === void 0 ? void 0 : settings.AppleLanguages) === null || _c === void 0 ? void 0 : _c[0]) !== null && _d !== void 0 ? _d : undefined;
|
|
16
16
|
}
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
17
|
+
function GetStatsigMetadataAdditions() {
|
|
18
|
+
var _a, _b, _c, _d, _e;
|
|
19
|
+
return {
|
|
20
|
+
appVersion: (_a = react_native_device_info_1.default.getVersion()) !== null && _a !== void 0 ? _a : undefined,
|
|
21
|
+
systemVersion: (_b = react_native_device_info_1.default.getSystemVersion()) !== null && _b !== void 0 ? _b : undefined,
|
|
22
|
+
systemName: (_c = react_native_device_info_1.default.getSystemName()) !== null && _c !== void 0 ? _c : undefined,
|
|
23
|
+
deviceModelName: (_d = react_native_device_info_1.default.getModel()) !== null && _d !== void 0 ? _d : undefined,
|
|
24
|
+
deviceModel: (_e = react_native_device_info_1.default.getDeviceId()) !== null && _e !== void 0 ? _e : undefined,
|
|
25
|
+
locale,
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
exports.GetStatsigMetadataAdditions = GetStatsigMetadataAdditions;
|
package/src/index.d.ts
CHANGED
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
import '
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
1
|
+
import { warmCachingFromAsyncStorage } from '@statsig/react-native-core';
|
|
2
|
+
declare const StatsigProviderRN: (props: import("@statsig/react-bindings").StatsigProviderProps & {
|
|
3
|
+
cacheWarming: import("@statsig/react-native-core").StatsigAsyncCacheWarming;
|
|
4
|
+
}) => JSX.Element | null;
|
|
5
|
+
export { StatsigProviderRN, warmCachingFromAsyncStorage };
|
|
6
|
+
export { StatsigContext, useDynamicConfig, useExperiment, useGate, useLayer, useStatsigOnDeviceEvalClient, useStatsigClient, useStatsigUser, } from '@statsig/react-bindings';
|
package/src/index.js
CHANGED
|
@@ -1,26 +1,17 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
-
};
|
|
16
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
exports.useLayer = exports.useGate = exports.useExperiment = exports.useDynamicConfig = exports.StatsigContext = void 0;
|
|
18
|
-
require("
|
|
19
|
-
|
|
20
|
-
|
|
3
|
+
exports.useStatsigUser = exports.useStatsigClient = exports.useStatsigOnDeviceEvalClient = exports.useLayer = exports.useGate = exports.useExperiment = exports.useDynamicConfig = exports.StatsigContext = exports.warmCachingFromAsyncStorage = exports.StatsigProviderRN = void 0;
|
|
4
|
+
const react_native_core_1 = require("@statsig/react-native-core");
|
|
5
|
+
Object.defineProperty(exports, "warmCachingFromAsyncStorage", { enumerable: true, get: function () { return react_native_core_1.warmCachingFromAsyncStorage; } });
|
|
6
|
+
const StatsigMetadataAdditions_1 = require("./StatsigMetadataAdditions");
|
|
7
|
+
const StatsigProviderRN = (0, react_native_core_1.GetStatsigProviderWithCacheWarming)((0, StatsigMetadataAdditions_1.GetStatsigMetadataAdditions)());
|
|
8
|
+
exports.StatsigProviderRN = StatsigProviderRN;
|
|
21
9
|
var react_bindings_1 = require("@statsig/react-bindings");
|
|
22
10
|
Object.defineProperty(exports, "StatsigContext", { enumerable: true, get: function () { return react_bindings_1.StatsigContext; } });
|
|
23
11
|
Object.defineProperty(exports, "useDynamicConfig", { enumerable: true, get: function () { return react_bindings_1.useDynamicConfig; } });
|
|
24
12
|
Object.defineProperty(exports, "useExperiment", { enumerable: true, get: function () { return react_bindings_1.useExperiment; } });
|
|
25
13
|
Object.defineProperty(exports, "useGate", { enumerable: true, get: function () { return react_bindings_1.useGate; } });
|
|
26
14
|
Object.defineProperty(exports, "useLayer", { enumerable: true, get: function () { return react_bindings_1.useLayer; } });
|
|
15
|
+
Object.defineProperty(exports, "useStatsigOnDeviceEvalClient", { enumerable: true, get: function () { return react_bindings_1.useStatsigOnDeviceEvalClient; } });
|
|
16
|
+
Object.defineProperty(exports, "useStatsigClient", { enumerable: true, get: function () { return react_bindings_1.useStatsigClient; } });
|
|
17
|
+
Object.defineProperty(exports, "useStatsigUser", { enumerable: true, get: function () { return react_bindings_1.useStatsigUser; } });
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
exports.warmCachingFromAsyncStorage = void 0;
|
|
13
|
-
const client_core_1 = require("@statsig/client-core");
|
|
14
|
-
function warmCachingFromAsyncStorage(client) {
|
|
15
|
-
return {
|
|
16
|
-
result: _loadCacheAsync(client.dataAdapter),
|
|
17
|
-
};
|
|
18
|
-
}
|
|
19
|
-
exports.warmCachingFromAsyncStorage = warmCachingFromAsyncStorage;
|
|
20
|
-
function _loadCacheAsync(adapter) {
|
|
21
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
22
|
-
const keys = yield client_core_1.Storage.getAllKeys();
|
|
23
|
-
const results = {};
|
|
24
|
-
yield Promise.all(keys.map((key) => __awaiter(this, void 0, void 0, function* () {
|
|
25
|
-
if (!key.startsWith(client_core_1.DataAdapterCachePrefix)) {
|
|
26
|
-
return;
|
|
27
|
-
}
|
|
28
|
-
const cache = yield client_core_1.Storage.getItem(key);
|
|
29
|
-
if (!cache) {
|
|
30
|
-
return;
|
|
31
|
-
}
|
|
32
|
-
const result = (0, client_core_1.typedJsonParse)(cache, 'source', 'Failed to parse cached result');
|
|
33
|
-
if (result && 'source' in result) {
|
|
34
|
-
results[key] = Object.assign(Object.assign({}, result), { source: 'Cache' });
|
|
35
|
-
}
|
|
36
|
-
})));
|
|
37
|
-
adapter.__setInMemoryCache(results);
|
|
38
|
-
});
|
|
39
|
-
}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { StatsigProviderProps } from '@statsig/react-bindings';
|
|
2
|
-
import { StatsigAsyncCacheWarming } from './AsyncStorageWarming';
|
|
3
|
-
type Props = StatsigProviderProps & {
|
|
4
|
-
cacheWarming: StatsigAsyncCacheWarming;
|
|
5
|
-
};
|
|
6
|
-
export declare function StatsigProviderRN(props: Props): JSX.Element;
|
|
7
|
-
export {};
|
package/src/StatsigProviderRN.js
DELETED
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.StatsigProviderRN = void 0;
|
|
4
|
-
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
-
const async_storage_1 = require("@react-native-async-storage/async-storage");
|
|
6
|
-
const react_1 = require("react");
|
|
7
|
-
const react_native_1 = require("react-native");
|
|
8
|
-
const client_core_1 = require("@statsig/client-core");
|
|
9
|
-
const react_bindings_1 = require("@statsig/react-bindings");
|
|
10
|
-
client_core_1.Storage.setProvider(Object.assign(Object.assign({}, async_storage_1.default), { getProviderName: () => 'AsyncStorage' }));
|
|
11
|
-
react_native_1.AppState.addEventListener('change', (nextAppState) => client_core_1.VisibilityChangeObserver.notify(nextAppState === 'active' ? 'foreground' : 'background'));
|
|
12
|
-
function StatsigProviderRN(props) {
|
|
13
|
-
const [isWarmed, setIsWarmed] = (0, react_1.useState)(false);
|
|
14
|
-
(0, react_1.useEffect)(() => {
|
|
15
|
-
props.cacheWarming.result
|
|
16
|
-
.catch((e) => {
|
|
17
|
-
client_core_1.Log.error('An error occurred while warming the Statsig client', e);
|
|
18
|
-
})
|
|
19
|
-
.finally(() => {
|
|
20
|
-
props.client.initializeSync();
|
|
21
|
-
setIsWarmed(true);
|
|
22
|
-
});
|
|
23
|
-
}, [props.cacheWarming.result]);
|
|
24
|
-
if (!isWarmed) {
|
|
25
|
-
return (0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, {});
|
|
26
|
-
}
|
|
27
|
-
return (0, jsx_runtime_1.jsx)(react_bindings_1.StatsigProvider, Object.assign({}, props));
|
|
28
|
-
}
|
|
29
|
-
exports.StatsigProviderRN = StatsigProviderRN;
|