@statsig/react-native-core 0.0.1-beta.17
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 +8 -0
- package/package.json +16 -0
- package/src/AsyncStorageWarming.d.ts +5 -0
- package/src/AsyncStorageWarming.js +39 -0
- package/src/StatsigProviderWithCacheWarming.d.ts +9 -0
- package/src/StatsigProviderWithCacheWarming.js +29 -0
- package/src/index.d.ts +2 -0
- package/src/index.js +23 -0
package/README.md
ADDED
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
# Statsig - React Native
|
|
2
|
+
|
|
3
|
+
> [!IMPORTANT]
|
|
4
|
+
> This version of the SDK is still in beta. The non-beta version can be found [here](https://github.com/statsig-io/react-native).
|
|
5
|
+
|
|
6
|
+
ReactNative specific additions for use with a Statsig Javascript SDK.
|
|
7
|
+
|
|
8
|
+
Learn more by visiting: https://docs.statsig.com/client/javascript-sdk
|
package/package.json
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@statsig/react-native-core",
|
|
3
|
+
"version": "0.0.1-beta.17",
|
|
4
|
+
"dependencies": {
|
|
5
|
+
"@statsig/client-core": "0.0.1-beta.17",
|
|
6
|
+
"@statsig/react-bindings": "0.0.1-beta.17"
|
|
7
|
+
},
|
|
8
|
+
"peerDependencies": {
|
|
9
|
+
"react": "^16.6.3 || ^17.0.0 || ^18.0.0",
|
|
10
|
+
"react-native": "0.*",
|
|
11
|
+
"@react-native-async-storage/async-storage": "1.*"
|
|
12
|
+
},
|
|
13
|
+
"type": "commonjs",
|
|
14
|
+
"main": "./src/index.js",
|
|
15
|
+
"typings": "./src/index.d.ts"
|
|
16
|
+
}
|
|
@@ -0,0 +1,39 @@
|
|
|
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.__primeInMemoryCache(results);
|
|
38
|
+
});
|
|
39
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { StatsigProviderProps } from '@statsig/react-bindings';
|
|
2
|
+
import { StatsigAsyncCacheWarming } from './AsyncStorageWarming';
|
|
3
|
+
type Props = StatsigProviderProps & {
|
|
4
|
+
cacheWarming: StatsigAsyncCacheWarming;
|
|
5
|
+
};
|
|
6
|
+
export declare function GetStatsigProviderWithCacheWarming(additions: {
|
|
7
|
+
[key: string]: string | undefined;
|
|
8
|
+
}): (props: Props) => JSX.Element | null;
|
|
9
|
+
export {};
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.GetStatsigProviderWithCacheWarming = void 0;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const react_1 = require("react");
|
|
6
|
+
const client_core_1 = require("@statsig/client-core");
|
|
7
|
+
const react_bindings_1 = require("@statsig/react-bindings");
|
|
8
|
+
function GetStatsigProviderWithCacheWarming(additions) {
|
|
9
|
+
client_core_1.StatsigMetadataProvider.add(additions);
|
|
10
|
+
return StatsigProviderWithCacheWarming;
|
|
11
|
+
}
|
|
12
|
+
exports.GetStatsigProviderWithCacheWarming = GetStatsigProviderWithCacheWarming;
|
|
13
|
+
function StatsigProviderWithCacheWarming(props) {
|
|
14
|
+
const [isWarmed, setIsWarmed] = (0, react_1.useState)(false);
|
|
15
|
+
(0, react_1.useEffect)(() => {
|
|
16
|
+
props.cacheWarming.result
|
|
17
|
+
.catch((e) => {
|
|
18
|
+
client_core_1.Log.error('An error occurred while warming the Statsig client', e);
|
|
19
|
+
})
|
|
20
|
+
.finally(() => {
|
|
21
|
+
props.client.initializeSync();
|
|
22
|
+
setIsWarmed(true);
|
|
23
|
+
});
|
|
24
|
+
}, [props.client, props.cacheWarming.result]);
|
|
25
|
+
if (!isWarmed) {
|
|
26
|
+
return null;
|
|
27
|
+
}
|
|
28
|
+
return (0, jsx_runtime_1.jsx)(react_bindings_1.StatsigProvider, Object.assign({}, props));
|
|
29
|
+
}
|
package/src/index.d.ts
ADDED
package/src/index.js
ADDED
|
@@ -0,0 +1,23 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
const async_storage_1 = require("@react-native-async-storage/async-storage");
|
|
18
|
+
const react_native_1 = require("react-native");
|
|
19
|
+
const client_core_1 = require("@statsig/client-core");
|
|
20
|
+
client_core_1.Storage.setProvider(Object.assign(Object.assign({}, async_storage_1.default), { getProviderName: () => 'AsyncStorage' }));
|
|
21
|
+
react_native_1.AppState.addEventListener('change', (nextAppState) => client_core_1.VisibilityChangeObserver.notify(nextAppState === 'active' ? 'foreground' : 'background'));
|
|
22
|
+
__exportStar(require("./AsyncStorageWarming"), exports);
|
|
23
|
+
__exportStar(require("./StatsigProviderWithCacheWarming"), exports);
|