@statsig/react-native-bindings 0.0.1-beta.1 → 0.0.1-beta.11
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/README.md +1 -1
- package/package.json +4 -3
- package/src/AsyncStorageWarming.d.ts +5 -0
- package/src/AsyncStorageWarming.js +37 -0
- package/src/StatsigMetadataAdditions.js +8 -8
- package/src/StatsigProviderRN.d.ts +7 -0
- package/src/StatsigProviderRN.js +29 -0
- package/src/index.d.ts +3 -1
- package/src/index.js +18 -10
package/README.md
CHANGED
package/package.json
CHANGED
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@statsig/react-native-bindings",
|
|
3
|
-
"version": "0.0.1-beta.
|
|
3
|
+
"version": "0.0.1-beta.11",
|
|
4
4
|
"dependencies": {
|
|
5
|
-
"@statsig/client-core": "
|
|
6
|
-
"@statsig/react-bindings": "
|
|
5
|
+
"@statsig/client-core": "0.0.1-beta.11",
|
|
6
|
+
"@statsig/react-bindings": "0.0.1-beta.11"
|
|
7
7
|
},
|
|
8
8
|
"peerDependencies": {
|
|
9
|
+
"react": "^16.6.3 || ^17.0.0 || ^18.0.0",
|
|
9
10
|
"react-native": "0.*",
|
|
10
11
|
"@react-native-async-storage/async-storage": "1.*",
|
|
11
12
|
"react-native-device-info": "10.*"
|
|
@@ -0,0 +1,37 @@
|
|
|
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
|
+
return result ? Object.assign(Object.assign({}, result), { source: 'Cache' }) : null;
|
|
34
|
+
})));
|
|
35
|
+
adapter.__setInMemoryCache(results);
|
|
36
|
+
});
|
|
37
|
+
}
|
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var _a, _b, _c, _d, _e, _f, _g, _h, _j;
|
|
3
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
4
|
+
const react_native_1 = require("react-native");
|
|
5
|
+
const react_native_device_info_1 = require("react-native-device-info");
|
|
6
|
+
const client_core_1 = require("@statsig/client-core");
|
|
7
|
+
let locale = undefined;
|
|
8
8
|
if (react_native_1.Platform.OS === 'android') {
|
|
9
|
-
|
|
9
|
+
const i18nManager = react_native_1.NativeModules['I18nManager'];
|
|
10
10
|
locale = (_a = i18nManager === null || i18nManager === void 0 ? void 0 : i18nManager.localIdentifer) !== null && _a !== void 0 ? _a : undefined;
|
|
11
11
|
}
|
|
12
12
|
if (react_native_1.Platform.OS === 'ios') {
|
|
13
|
-
|
|
14
|
-
|
|
13
|
+
const settingsManager = react_native_1.NativeModules['SettingsManager'];
|
|
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
17
|
client_core_1.StatsigMetadataProvider.add({
|
|
@@ -20,5 +20,5 @@ client_core_1.StatsigMetadataProvider.add({
|
|
|
20
20
|
systemName: (_g = react_native_device_info_1.default.getSystemName()) !== null && _g !== void 0 ? _g : undefined,
|
|
21
21
|
deviceModelName: (_h = react_native_device_info_1.default.getModel()) !== null && _h !== void 0 ? _h : undefined,
|
|
22
22
|
deviceModel: (_j = react_native_device_info_1.default.getDeviceId()) !== null && _j !== void 0 ? _j : undefined,
|
|
23
|
-
locale
|
|
23
|
+
locale,
|
|
24
24
|
});
|
|
@@ -0,0 +1,7 @@
|
|
|
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 {};
|
|
@@ -0,0 +1,29 @@
|
|
|
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;
|
package/src/index.d.ts
CHANGED
|
@@ -1,2 +1,4 @@
|
|
|
1
1
|
import './StatsigMetadataAdditions';
|
|
2
|
-
export
|
|
2
|
+
export * from './AsyncStorageWarming';
|
|
3
|
+
export * from './StatsigProviderRN';
|
|
4
|
+
export { StatsigContext, useDynamicConfig, useExperiment, useGate, useLayer, } from '@statsig/react-bindings';
|
package/src/index.js
CHANGED
|
@@ -1,18 +1,26 @@
|
|
|
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
|
+
};
|
|
2
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.useLayer = exports.
|
|
4
|
-
var async_storage_1 = require("@react-native-async-storage/async-storage");
|
|
5
|
-
var react_native_1 = require("react-native");
|
|
6
|
-
var client_core_1 = require("@statsig/client-core");
|
|
17
|
+
exports.useLayer = exports.useGate = exports.useExperiment = exports.useDynamicConfig = exports.StatsigContext = void 0;
|
|
7
18
|
require("./StatsigMetadataAdditions");
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
return client_core_1.VisibilityChangeObserver.notify(nextAppState === 'active' ? 'foreground' : 'background');
|
|
11
|
-
});
|
|
19
|
+
__exportStar(require("./AsyncStorageWarming"), exports);
|
|
20
|
+
__exportStar(require("./StatsigProviderRN"), exports);
|
|
12
21
|
var react_bindings_1 = require("@statsig/react-bindings");
|
|
13
22
|
Object.defineProperty(exports, "StatsigContext", { enumerable: true, get: function () { return react_bindings_1.StatsigContext; } });
|
|
14
|
-
Object.defineProperty(exports, "StatsigProvider", { enumerable: true, get: function () { return react_bindings_1.StatsigProvider; } });
|
|
15
|
-
Object.defineProperty(exports, "useGate", { enumerable: true, get: function () { return react_bindings_1.useGate; } });
|
|
16
23
|
Object.defineProperty(exports, "useDynamicConfig", { enumerable: true, get: function () { return react_bindings_1.useDynamicConfig; } });
|
|
17
24
|
Object.defineProperty(exports, "useExperiment", { enumerable: true, get: function () { return react_bindings_1.useExperiment; } });
|
|
25
|
+
Object.defineProperty(exports, "useGate", { enumerable: true, get: function () { return react_bindings_1.useGate; } });
|
|
18
26
|
Object.defineProperty(exports, "useLayer", { enumerable: true, get: function () { return react_bindings_1.useLayer; } });
|