@ninetailed/experience.js-next 7.5.0 → 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 CHANGED
@@ -38,13 +38,11 @@ function __rest(s, e) {
38
38
  }
39
39
 
40
40
  const Tracker = ({
41
- isFirstPageviewAlreadyTracked
41
+ onRouteChange
42
42
  }) => {
43
43
  const router$1 = router.useRouter();
44
- const {
45
- page
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
- page();
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
- return jsxRuntime.jsxs(experience_jsReact.NinetailedProvider, Object.assign({}, props, {
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
- isFirstPageviewAlreadyTracked: false
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
- isFirstPageviewAlreadyTracked
38
+ onRouteChange
39
39
  }) => {
40
40
  const router = useRouter();
41
- const {
42
- page
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
- page();
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
- return jsxs(NinetailedProvider$1, Object.assign({}, props, {
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
- isFirstPageviewAlreadyTracked: false
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.5.0",
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.5.0",
15
- "@ninetailed/experience.js-plugin-ssr": "7.5.0-beta.9",
16
- "@ninetailed/experience.js-react": "7.5.0",
17
- "@ninetailed/experience.js-shared": "7.5.0"
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
- export declare const NinetailedProvider: React.FC<React.PropsWithChildren<NinetailedProviderProps>>;
3
+ import { OnRouteChange } from './Tracker';
4
+ export declare const NinetailedProvider: React.FC<React.PropsWithChildren<NinetailedProviderProps & {
5
+ onRouteChange?: OnRouteChange;
6
+ }>>;
@@ -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
- isFirstPageviewAlreadyTracked: boolean;
7
+ onRouteChange?: OnRouteChange;
4
8
  };
5
9
  export declare const Tracker: React.FC<React.PropsWithChildren<TrackerProps>>;
6
10
  export {};