-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathPageEvents.tsx
53 lines (44 loc) · 1.55 KB
/
PageEvents.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
'use client';
import {usePathname, useSearchParams} from 'next/navigation';
import React, {Suspense} from 'react';
import {
routeChangeEnd,
routeChangeError,
routeChangeStart,
} from '../utils/event';
import {pageview} from '../utils/ga/gtag';
export const PageEventsImplementation: React.FC = () => {
const pathname = usePathname();
const searchParams = useSearchParams();
// Chromiumのみ対応
React.useEffect(() => {
// まだ試験的機能なので型情報がない。そのため、一旦anyにしてしまう
// mdn: https://developer.mozilla.org/en-US/docs/Web/API/Window/navigation
// eslint-disable-next-line @typescript-eslint/no-explicit-any
const {navigation} = window as any;
if (!navigation) {
return;
}
navigation.addEventListener('navigate', routeChangeStart);
navigation.addEventListener('navigateerror', routeChangeError);
navigation.addEventListener('navigatesuccess', routeChangeEnd);
return () => {
navigation.removeEventListener('navigate', routeChangeStart);
navigation.removeEventListener('navigateerror', routeChangeError);
navigation.removeEventListener('navigatesuccess', routeChangeEnd);
};
}, []);
// TODO: 一時的対応。router.eventsが復活したら削除
React.useEffect(() => {
const url = pathname + searchParams.toString();
// GA
pageview(url);
routeChangeEnd();
}, [pathname, searchParams]);
return null;
};
export const PageEvents = () => (
<Suspense fallback={null}>
<PageEventsImplementation />
</Suspense>
);