@ninetailed/experience.js-next 7.5.0-beta.9 → 7.6.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/index.cjs +16 -8
- package/index.js +16 -8
- package/package.json +5 -5
- package/src/lib/NinetailedProvider.d.ts +4 -1
- package/src/lib/Tracker.d.ts +5 -1
package/index.cjs
CHANGED
|
@@ -38,13 +38,11 @@ function __rest(s, e) {
|
|
|
38
38
|
}
|
|
39
39
|
|
|
40
40
|
const Tracker = ({
|
|
41
|
-
|
|
41
|
+
onRouteChange
|
|
42
42
|
}) => {
|
|
43
43
|
const router$1 = router.useRouter();
|
|
44
|
-
const
|
|
45
|
-
|
|
46
|
-
} = experience_jsReact.useNinetailed();
|
|
47
|
-
const lastFiredPageRef = react.useRef(isFirstPageviewAlreadyTracked ? 'tracked' : 'none');
|
|
44
|
+
const ninetailed = experience_jsReact.useNinetailed();
|
|
45
|
+
const lastFiredPageRef = react.useRef('none');
|
|
48
46
|
react.useEffect(() => {
|
|
49
47
|
experience_jsShared.logger.debug('Ninetailed Next.js Tracker', 'The useEffect hook to listen for route changes got called. On instantiation the last fired page is:', lastFiredPageRef.current);
|
|
50
48
|
const handleRouteChange = url => {
|
|
@@ -56,7 +54,13 @@ const Tracker = ({
|
|
|
56
54
|
});
|
|
57
55
|
if (!isPageAlreadyTracked) {
|
|
58
56
|
experience_jsShared.logger.debug('Ninetailed Next.js Tracker', 'Page is not tracked yet, calling the ninetailed.page function.');
|
|
59
|
-
|
|
57
|
+
if (typeof onRouteChange === 'function') {
|
|
58
|
+
onRouteChange({
|
|
59
|
+
isInitialRoute: lastFiredPageRef.current === 'none'
|
|
60
|
+
}, ninetailed);
|
|
61
|
+
} else {
|
|
62
|
+
ninetailed.page();
|
|
63
|
+
}
|
|
60
64
|
experience_jsShared.logger.debug('Ninetailed Next.js Tracker', 'Page got tracked, setting the last fired page to the current url.', url);
|
|
61
65
|
lastFiredPageRef.current = url;
|
|
62
66
|
}
|
|
@@ -76,9 +80,13 @@ const NinetailedProvider = _a => {
|
|
|
76
80
|
children
|
|
77
81
|
} = _a,
|
|
78
82
|
props = __rest(_a, ["children"]);
|
|
79
|
-
|
|
83
|
+
const {
|
|
84
|
+
onRouteChange
|
|
85
|
+
} = props,
|
|
86
|
+
providerProps = __rest(props, ["onRouteChange"]);
|
|
87
|
+
return jsxRuntime.jsxs(experience_jsReact.NinetailedProvider, Object.assign({}, providerProps, {
|
|
80
88
|
children: [jsxRuntime.jsx(Tracker, {
|
|
81
|
-
|
|
89
|
+
onRouteChange: onRouteChange
|
|
82
90
|
}), children]
|
|
83
91
|
}));
|
|
84
92
|
};
|
package/index.js
CHANGED
|
@@ -35,13 +35,11 @@ function __rest(s, e) {
|
|
|
35
35
|
}
|
|
36
36
|
|
|
37
37
|
const Tracker = ({
|
|
38
|
-
|
|
38
|
+
onRouteChange
|
|
39
39
|
}) => {
|
|
40
40
|
const router = useRouter();
|
|
41
|
-
const
|
|
42
|
-
|
|
43
|
-
} = useNinetailed();
|
|
44
|
-
const lastFiredPageRef = useRef(isFirstPageviewAlreadyTracked ? 'tracked' : 'none');
|
|
41
|
+
const ninetailed = useNinetailed();
|
|
42
|
+
const lastFiredPageRef = useRef('none');
|
|
45
43
|
useEffect(() => {
|
|
46
44
|
logger.debug('Ninetailed Next.js Tracker', 'The useEffect hook to listen for route changes got called. On instantiation the last fired page is:', lastFiredPageRef.current);
|
|
47
45
|
const handleRouteChange = url => {
|
|
@@ -53,7 +51,13 @@ const Tracker = ({
|
|
|
53
51
|
});
|
|
54
52
|
if (!isPageAlreadyTracked) {
|
|
55
53
|
logger.debug('Ninetailed Next.js Tracker', 'Page is not tracked yet, calling the ninetailed.page function.');
|
|
56
|
-
|
|
54
|
+
if (typeof onRouteChange === 'function') {
|
|
55
|
+
onRouteChange({
|
|
56
|
+
isInitialRoute: lastFiredPageRef.current === 'none'
|
|
57
|
+
}, ninetailed);
|
|
58
|
+
} else {
|
|
59
|
+
ninetailed.page();
|
|
60
|
+
}
|
|
57
61
|
logger.debug('Ninetailed Next.js Tracker', 'Page got tracked, setting the last fired page to the current url.', url);
|
|
58
62
|
lastFiredPageRef.current = url;
|
|
59
63
|
}
|
|
@@ -73,9 +77,13 @@ const NinetailedProvider = _a => {
|
|
|
73
77
|
children
|
|
74
78
|
} = _a,
|
|
75
79
|
props = __rest(_a, ["children"]);
|
|
76
|
-
|
|
80
|
+
const {
|
|
81
|
+
onRouteChange
|
|
82
|
+
} = props,
|
|
83
|
+
providerProps = __rest(props, ["onRouteChange"]);
|
|
84
|
+
return jsxs(NinetailedProvider$1, Object.assign({}, providerProps, {
|
|
77
85
|
children: [jsx(Tracker, {
|
|
78
|
-
|
|
86
|
+
onRouteChange: onRouteChange
|
|
79
87
|
}), children]
|
|
80
88
|
}));
|
|
81
89
|
};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ninetailed/experience.js-next",
|
|
3
|
-
"version": "7.
|
|
3
|
+
"version": "7.6.0-beta.1",
|
|
4
4
|
"peerDependencies": {
|
|
5
5
|
"next": ">=9.0.0",
|
|
6
6
|
"react": ">=16.8.0"
|
|
@@ -11,9 +11,9 @@
|
|
|
11
11
|
"type": "module",
|
|
12
12
|
"types": "./src/index.d.ts",
|
|
13
13
|
"dependencies": {
|
|
14
|
-
"@ninetailed/experience.js": "7.
|
|
15
|
-
"@ninetailed/experience.js-plugin-ssr": "7.5.0
|
|
16
|
-
"@ninetailed/experience.js-react": "7.
|
|
17
|
-
"@ninetailed/experience.js-shared": "7.
|
|
14
|
+
"@ninetailed/experience.js": "7.6.0-beta.1",
|
|
15
|
+
"@ninetailed/experience.js-plugin-ssr": "7.5.0",
|
|
16
|
+
"@ninetailed/experience.js-react": "7.6.0-beta.1",
|
|
17
|
+
"@ninetailed/experience.js-shared": "7.6.0-beta.1"
|
|
18
18
|
}
|
|
19
19
|
}
|
|
@@ -1,3 +1,6 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import { NinetailedProviderProps } from '@ninetailed/experience.js-react';
|
|
3
|
-
|
|
3
|
+
import { OnRouteChange } from './Tracker';
|
|
4
|
+
export declare const NinetailedProvider: React.FC<React.PropsWithChildren<NinetailedProviderProps & {
|
|
5
|
+
onRouteChange?: OnRouteChange;
|
|
6
|
+
}>>;
|
package/src/lib/Tracker.d.ts
CHANGED
|
@@ -1,6 +1,10 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
+
import { NinetailedInstance } from '@ninetailed/experience.js';
|
|
3
|
+
export type OnRouteChange = (routeInfo: {
|
|
4
|
+
isInitialRoute: boolean;
|
|
5
|
+
}, ninetailed: NinetailedInstance) => void;
|
|
2
6
|
type TrackerProps = {
|
|
3
|
-
|
|
7
|
+
onRouteChange?: OnRouteChange;
|
|
4
8
|
};
|
|
5
9
|
export declare const Tracker: React.FC<React.PropsWithChildren<TrackerProps>>;
|
|
6
10
|
export {};
|