-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathLenkepanelMedLogging.tsx
34 lines (28 loc) · 1.12 KB
/
LenkepanelMedLogging.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
import {MouseEventHandler} from 'react';
import {loggNavigasjon} from '../utils/analytics';
import {Link, LinkProps, useLocation} from 'react-router-dom';
import {LinkPanel, LinkPanelProps} from "@navikt/ds-react";
interface Props extends LinkPanelProps{
loggLenketekst: string;
}
export const LenkepanelMedLogging= (props: Props) => {
const {onClick, loggLenketekst, ...rest} = props;
const {pathname} = useLocation()
const onClickLog: MouseEventHandler<HTMLAnchorElement> = event => {
loggNavigasjon(props.href, loggLenketekst, pathname);
onClick?.(event);
};
return <LinkPanel onClick={onClickLog} {...rest} />;
};
interface InternalProps extends LinkProps{
loggLenketekst: string;
}
export const InternalLenkepanelMedLogging= (props: InternalProps) => {
const {onClick, loggLenketekst, ...rest} = props;
const {pathname} = useLocation()
const onClickLog: MouseEventHandler<HTMLAnchorElement> = event => {
loggNavigasjon(JSON.stringify(props.to), loggLenketekst, pathname);
onClick?.(event);
};
return <LinkPanel as={Link} onClick={onClickLog} {...rest} />;
};