@grainql/analytics-web 1.7.2 → 2.0.0
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 +71 -777
- package/dist/cjs/index.d.ts +35 -2
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/react/GrainProvider.d.ts +11 -0
- package/dist/cjs/react/GrainProvider.d.ts.map +1 -0
- package/dist/cjs/react/GrainProvider.js +79 -0
- package/dist/cjs/react/GrainProvider.js.map +1 -0
- package/dist/cjs/react/context.d.ts +11 -0
- package/dist/cjs/react/context.d.ts.map +1 -0
- package/dist/cjs/react/context.js +43 -0
- package/dist/cjs/react/context.js.map +1 -0
- package/dist/cjs/react/hooks/useAllConfigs.d.ts +8 -0
- package/dist/cjs/react/hooks/useAllConfigs.d.ts.map +1 -0
- package/dist/cjs/react/hooks/useAllConfigs.js +112 -0
- package/dist/cjs/react/hooks/useAllConfigs.js.map +1 -0
- package/dist/cjs/react/hooks/useConfig.d.ts +9 -0
- package/dist/cjs/react/hooks/useConfig.d.ts.map +1 -0
- package/dist/cjs/react/hooks/useConfig.js +116 -0
- package/dist/cjs/react/hooks/useConfig.js.map +1 -0
- package/dist/cjs/react/hooks/useGrainAnalytics.d.ts +6 -0
- package/dist/cjs/react/hooks/useGrainAnalytics.d.ts.map +1 -0
- package/dist/cjs/react/hooks/useGrainAnalytics.js +50 -0
- package/dist/cjs/react/hooks/useGrainAnalytics.js.map +1 -0
- package/dist/cjs/react/hooks/useTrack.d.ts +9 -0
- package/dist/cjs/react/hooks/useTrack.d.ts.map +1 -0
- package/dist/cjs/react/hooks/useTrack.js +53 -0
- package/dist/cjs/react/hooks/useTrack.js.map +1 -0
- package/dist/cjs/react/index.d.ts +36 -0
- package/dist/cjs/react/index.d.ts.map +1 -0
- package/dist/cjs/react/index.js +45 -0
- package/dist/cjs/react/index.js.map +1 -0
- package/dist/cjs/react/types.d.ts +33 -0
- package/dist/cjs/react/types.d.ts.map +1 -0
- package/dist/cjs/react/types.js +6 -0
- package/dist/cjs/react/types.js.map +1 -0
- package/dist/esm/index.d.ts +35 -2
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/react/GrainProvider.d.ts +11 -0
- package/dist/esm/react/GrainProvider.d.ts.map +1 -0
- package/dist/esm/react/GrainProvider.js +43 -0
- package/dist/esm/react/GrainProvider.js.map +1 -0
- package/dist/esm/react/context.d.ts +11 -0
- package/dist/esm/react/context.d.ts.map +1 -0
- package/dist/esm/react/context.js +7 -0
- package/dist/esm/react/context.js.map +1 -0
- package/dist/esm/react/hooks/useAllConfigs.d.ts +8 -0
- package/dist/esm/react/hooks/useAllConfigs.d.ts.map +1 -0
- package/dist/esm/react/hooks/useAllConfigs.js +76 -0
- package/dist/esm/react/hooks/useAllConfigs.js.map +1 -0
- package/dist/esm/react/hooks/useConfig.d.ts +9 -0
- package/dist/esm/react/hooks/useConfig.d.ts.map +1 -0
- package/dist/esm/react/hooks/useConfig.js +80 -0
- package/dist/esm/react/hooks/useConfig.js.map +1 -0
- package/dist/esm/react/hooks/useGrainAnalytics.d.ts +6 -0
- package/dist/esm/react/hooks/useGrainAnalytics.d.ts.map +1 -0
- package/dist/esm/react/hooks/useGrainAnalytics.js +14 -0
- package/dist/esm/react/hooks/useGrainAnalytics.js.map +1 -0
- package/dist/esm/react/hooks/useTrack.d.ts +9 -0
- package/dist/esm/react/hooks/useTrack.d.ts.map +1 -0
- package/dist/esm/react/hooks/useTrack.js +17 -0
- package/dist/esm/react/hooks/useTrack.js.map +1 -0
- package/dist/esm/react/index.d.ts +36 -0
- package/dist/esm/react/index.d.ts.map +1 -0
- package/dist/esm/react/index.js +37 -0
- package/dist/esm/react/index.js.map +1 -0
- package/dist/esm/react/types.d.ts +33 -0
- package/dist/esm/react/types.d.ts.map +1 -0
- package/dist/esm/react/types.js +5 -0
- package/dist/esm/react/types.js.map +1 -0
- package/dist/index.d.ts +35 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.global.dev.js +124 -14
- package/dist/index.global.dev.js.map +2 -2
- package/dist/index.global.js +2 -2
- package/dist/index.global.js.map +3 -3
- package/dist/index.js +147 -15
- package/dist/index.mjs +147 -15
- package/dist/react/index.d.ts +405 -0
- package/dist/react/index.d.ts.map +1 -0
- package/dist/react/index.js +1181 -0
- package/dist/react/index.mjs +1176 -0
- package/dist/react/react/GrainProvider.d.ts +11 -0
- package/dist/react/react/GrainProvider.d.ts.map +1 -0
- package/dist/react/react/GrainProvider.js +45 -0
- package/dist/react/react/GrainProvider.mjs +42 -0
- package/dist/react/react/context.d.ts +11 -0
- package/dist/react/react/context.d.ts.map +1 -0
- package/dist/react/react/context.js +9 -0
- package/dist/react/react/context.mjs +6 -0
- package/dist/react/react/hooks/useAllConfigs.d.ts +8 -0
- package/dist/react/react/hooks/useAllConfigs.d.ts.map +1 -0
- package/dist/react/react/hooks/useAllConfigs.js +78 -0
- package/dist/react/react/hooks/useAllConfigs.mjs +75 -0
- package/dist/react/react/hooks/useConfig.d.ts +9 -0
- package/dist/react/react/hooks/useConfig.d.ts.map +1 -0
- package/dist/react/react/hooks/useConfig.js +82 -0
- package/dist/react/react/hooks/useConfig.mjs +79 -0
- package/dist/react/react/hooks/useGrainAnalytics.d.ts +6 -0
- package/dist/react/react/hooks/useGrainAnalytics.d.ts.map +1 -0
- package/dist/react/react/hooks/useGrainAnalytics.js +16 -0
- package/dist/react/react/hooks/useGrainAnalytics.mjs +13 -0
- package/dist/react/react/hooks/useTrack.d.ts +9 -0
- package/dist/react/react/hooks/useTrack.d.ts.map +1 -0
- package/dist/react/react/hooks/useTrack.js +19 -0
- package/dist/react/react/hooks/useTrack.mjs +16 -0
- package/dist/react/react/index.d.ts +36 -0
- package/dist/react/react/index.d.ts.map +1 -0
- package/dist/react/react/index.js +44 -0
- package/dist/react/react/index.mjs +36 -0
- package/dist/react/react/types.d.ts +33 -0
- package/dist/react/react/types.d.ts.map +1 -0
- package/dist/react/react/types.js +5 -0
- package/dist/react/react/types.mjs +4 -0
- package/package.json +20 -2
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Grain Analytics React Hooks
|
|
3
|
+
*
|
|
4
|
+
* React integration for @grainql/analytics-web
|
|
5
|
+
*
|
|
6
|
+
* @example
|
|
7
|
+
* ```tsx
|
|
8
|
+
* import { GrainProvider, useConfig, useTrack } from '@grainql/analytics-web/react';
|
|
9
|
+
*
|
|
10
|
+
* // Pattern 1: Provider-managed client
|
|
11
|
+
* <GrainProvider config={{ tenantId: 'xxx' }}>
|
|
12
|
+
* <App />
|
|
13
|
+
* </GrainProvider>
|
|
14
|
+
*
|
|
15
|
+
* // Pattern 2: External client
|
|
16
|
+
* const grain = new GrainAnalytics({ tenantId: 'xxx' });
|
|
17
|
+
* <GrainProvider client={grain}>
|
|
18
|
+
* <App />
|
|
19
|
+
* </GrainProvider>
|
|
20
|
+
*
|
|
21
|
+
* // Use hooks in components
|
|
22
|
+
* function MyComponent() {
|
|
23
|
+
* const { value } = useConfig('hero_variant');
|
|
24
|
+
* const track = useTrack();
|
|
25
|
+
*
|
|
26
|
+
* return <button onClick={() => track('clicked')}>Click</button>;
|
|
27
|
+
* }
|
|
28
|
+
* ```
|
|
29
|
+
*/
|
|
30
|
+
// Provider
|
|
31
|
+
export { GrainProvider } from './GrainProvider';
|
|
32
|
+
// Hooks
|
|
33
|
+
export { useGrainAnalytics } from './hooks/useGrainAnalytics';
|
|
34
|
+
export { useConfig } from './hooks/useConfig';
|
|
35
|
+
export { useAllConfigs } from './hooks/useAllConfigs';
|
|
36
|
+
export { useTrack } from './hooks/useTrack';
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* React-specific types for Grain Analytics
|
|
3
|
+
*/
|
|
4
|
+
import type { GrainAnalytics, GrainConfig, SendEventOptions } from '../index';
|
|
5
|
+
export interface GrainProviderProps {
|
|
6
|
+
children: React.ReactNode;
|
|
7
|
+
client?: GrainAnalytics;
|
|
8
|
+
config?: GrainConfig;
|
|
9
|
+
}
|
|
10
|
+
export interface UseConfigOptions {
|
|
11
|
+
forceRefresh?: boolean;
|
|
12
|
+
immediateKeys?: string[];
|
|
13
|
+
properties?: Record<string, string>;
|
|
14
|
+
}
|
|
15
|
+
export interface UseConfigResult {
|
|
16
|
+
value: string | undefined;
|
|
17
|
+
isRefreshing: boolean;
|
|
18
|
+
error: Error | null;
|
|
19
|
+
refresh: () => Promise<void>;
|
|
20
|
+
}
|
|
21
|
+
export interface UseAllConfigsOptions {
|
|
22
|
+
forceRefresh?: boolean;
|
|
23
|
+
immediateKeys?: string[];
|
|
24
|
+
properties?: Record<string, string>;
|
|
25
|
+
}
|
|
26
|
+
export interface UseAllConfigsResult {
|
|
27
|
+
configs: Record<string, string>;
|
|
28
|
+
isRefreshing: boolean;
|
|
29
|
+
error: Error | null;
|
|
30
|
+
refresh: () => Promise<void>;
|
|
31
|
+
}
|
|
32
|
+
export type TrackFunction = (eventName: string, properties?: Record<string, unknown>, options?: SendEventOptions) => Promise<void>;
|
|
33
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/react/types.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,cAAc,EAAE,WAAW,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAC;AAE9E,MAAM,WAAW,kBAAkB;IACjC,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,MAAM,CAAC,EAAE,cAAc,CAAC;IACxB,MAAM,CAAC,EAAE,WAAW,CAAC;CACtB;AAED,MAAM,WAAW,gBAAgB;IAC/B,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,aAAa,CAAC,EAAE,MAAM,EAAE,CAAC;IACzB,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CACrC;AAED,MAAM,WAAW,eAAe;IAC9B,KAAK,EAAE,MAAM,GAAG,SAAS,CAAC;IAC1B,YAAY,EAAE,OAAO,CAAC;IACtB,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IACpB,OAAO,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;CAC9B;AAED,MAAM,WAAW,oBAAoB;IACnC,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,aAAa,CAAC,EAAE,MAAM,EAAE,CAAC;IACzB,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CACrC;AAED,MAAM,WAAW,mBAAmB;IAClC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAChC,YAAY,EAAE,OAAO,CAAC;IACtB,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IACpB,OAAO,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;CAC9B;AAED,MAAM,MAAM,aAAa,GAAG,CAC1B,SAAS,EAAE,MAAM,EACjB,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EACpC,OAAO,CAAC,EAAE,gBAAgB,KACvB,OAAO,CAAC,IAAI,CAAC,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@grainql/analytics-web",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "2.0.0",
|
|
4
4
|
"description": "Lightweight TypeScript SDK for sending analytics events and managing remote configurations via Grain's REST API",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"module": "dist/index.mjs",
|
|
@@ -10,16 +10,30 @@
|
|
|
10
10
|
"import": "./dist/index.mjs",
|
|
11
11
|
"require": "./dist/index.js",
|
|
12
12
|
"types": "./dist/index.d.ts"
|
|
13
|
+
},
|
|
14
|
+
"./react": {
|
|
15
|
+
"import": "./dist/react/index.mjs",
|
|
16
|
+
"require": "./dist/react/index.js",
|
|
17
|
+
"types": "./dist/react/index.d.ts"
|
|
18
|
+
}
|
|
19
|
+
},
|
|
20
|
+
"peerDependencies": {
|
|
21
|
+
"react": ">=16.8.0"
|
|
22
|
+
},
|
|
23
|
+
"peerDependenciesMeta": {
|
|
24
|
+
"react": {
|
|
25
|
+
"optional": true
|
|
13
26
|
}
|
|
14
27
|
},
|
|
15
28
|
"files": [
|
|
16
29
|
"dist/"
|
|
17
30
|
],
|
|
18
31
|
"scripts": {
|
|
19
|
-
"build": "npm run build:types && npm run build:esm && npm run build:cjs && npm run build:iife",
|
|
32
|
+
"build": "npm run build:types && npm run build:esm && npm run build:cjs && npm run build:react && npm run build:iife",
|
|
20
33
|
"build:types": "tsc --declaration --emitDeclarationOnly --outDir dist",
|
|
21
34
|
"build:esm": "tsc --module esnext --target es2020 --outDir dist/esm && mv dist/esm/index.js dist/index.mjs",
|
|
22
35
|
"build:cjs": "tsc --module commonjs --target es2020 --outDir dist/cjs && mv dist/cjs/index.js dist/index.js",
|
|
36
|
+
"build:react": "node scripts/build-react.js",
|
|
23
37
|
"build:iife": "node scripts/build-iife.js",
|
|
24
38
|
"clean": "rm -rf dist",
|
|
25
39
|
"test": "jest",
|
|
@@ -43,12 +57,16 @@
|
|
|
43
57
|
"devDependencies": {
|
|
44
58
|
"@jest/globals": "^30.0.5",
|
|
45
59
|
"@size-limit/preset-small-lib": "^11.2.0",
|
|
60
|
+
"@testing-library/react": "^16.0.0",
|
|
46
61
|
"@types/jest": "^30.0.0",
|
|
47
62
|
"@types/jsdom": "^21.1.7",
|
|
63
|
+
"@types/react": "^18.0.0",
|
|
48
64
|
"esbuild": "^0.19.0",
|
|
49
65
|
"jest": "^30.0.5",
|
|
50
66
|
"jest-environment-jsdom": "^30.0.5",
|
|
51
67
|
"jsdom": "^26.1.0",
|
|
68
|
+
"react": "^18.0.0",
|
|
69
|
+
"react-dom": "^18.0.0",
|
|
52
70
|
"size-limit": "^11.2.0",
|
|
53
71
|
"ts-jest": "^29.4.1",
|
|
54
72
|
"typescript": "^5.5.3"
|