mirror of
https://github.com/kremalicious/umami.git
synced 2024-11-22 09:57:00 +01:00
Replaced tooltip in pageviews chart.
This commit is contained in:
parent
9c5762b8a2
commit
418793feaf
@ -1,10 +1,11 @@
|
|||||||
import React, { useState, useRef, useEffect, useCallback } from 'react';
|
import React, { useState, useRef, useEffect, useCallback } from 'react';
|
||||||
|
import ReactTooltip from 'react-tooltip';
|
||||||
import classNames from 'classnames';
|
import classNames from 'classnames';
|
||||||
import ChartJS from 'chart.js';
|
import ChartJS from 'chart.js';
|
||||||
import { format } from 'date-fns';
|
import { format } from 'date-fns';
|
||||||
import styles from './PageviewsChart.module.css';
|
import styles from './PageviewsChart.module.css';
|
||||||
|
|
||||||
export default function PageviewsChart({ data, unit, className, children }) {
|
export default function PageviewsChart({ websiteId, data, unit, className, children }) {
|
||||||
const canvas = useRef();
|
const canvas = useRef();
|
||||||
const chart = useRef();
|
const chart = useRef();
|
||||||
const [tooltip, setTooltip] = useState({});
|
const [tooltip, setTooltip] = useState({});
|
||||||
@ -30,17 +31,14 @@ export default function PageviewsChart({ data, unit, className, children }) {
|
|||||||
);
|
);
|
||||||
|
|
||||||
const renderTooltip = model => {
|
const renderTooltip = model => {
|
||||||
const { caretX, caretY, opacity, title, body, labelColors } = model;
|
const { opacity, title, body, labelColors } = model;
|
||||||
|
|
||||||
if (!opacity) {
|
if (!opacity) {
|
||||||
setTooltip({ opacity });
|
setTooltip(null);
|
||||||
} else {
|
} else {
|
||||||
const [label, value] = body[0].lines[0].split(':');
|
const [label, value] = body[0].lines[0].split(':');
|
||||||
|
|
||||||
setTooltip({
|
setTooltip({
|
||||||
top: caretY,
|
|
||||||
left: caretX,
|
|
||||||
opacity,
|
|
||||||
title: title[0],
|
title: title[0],
|
||||||
value,
|
value,
|
||||||
label,
|
label,
|
||||||
@ -139,16 +137,22 @@ export default function PageviewsChart({ data, unit, className, children }) {
|
|||||||
}, [data]);
|
}, [data]);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className={classNames(styles.chart, className)}>
|
<div
|
||||||
|
data-tip=""
|
||||||
|
data-for={`${websiteId}-tooltip`}
|
||||||
|
className={classNames(styles.chart, className)}
|
||||||
|
>
|
||||||
<canvas ref={canvas} width={960} height={400} />
|
<canvas ref={canvas} width={960} height={400} />
|
||||||
<Tootip {...tooltip} />
|
<ReactTooltip id={`${websiteId}-tooltip`}>
|
||||||
|
{tooltip ? <Tooltip {...tooltip} /> : null}
|
||||||
|
</ReactTooltip>
|
||||||
{children}
|
{children}
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
const Tootip = ({ top, left, opacity, title, value, label, labelColor }) => (
|
const Tooltip = ({ title, value, label, labelColor }) => (
|
||||||
<div className={styles.tooltip} style={{ top, left, opacity }}>
|
<div className={styles.tooltip}>
|
||||||
<div className={styles.content}>
|
<div className={styles.content}>
|
||||||
<div className={styles.title}>{title}</div>
|
<div className={styles.title}>{title}</div>
|
||||||
<div className={styles.metric}>
|
<div className={styles.metric}>
|
||||||
|
@ -3,8 +3,6 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
.tooltip {
|
.tooltip {
|
||||||
opacity: 0;
|
|
||||||
position: absolute;
|
|
||||||
pointer-events: none;
|
pointer-events: none;
|
||||||
z-index: 1;
|
z-index: 1;
|
||||||
}
|
}
|
||||||
@ -14,26 +12,8 @@
|
|||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
justify-content: center;
|
justify-content: center;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
color: #000;
|
color: #fff;
|
||||||
text-shadow: -1px -1px 0 #fff, 1px -1px 0 #fff, -1px 1px 0 #fff, 1px 1px 0 #fff;
|
|
||||||
text-align: center;
|
text-align: center;
|
||||||
width: 150px;
|
|
||||||
height: 50px;
|
|
||||||
transform: translate(-50%, -60px);
|
|
||||||
backdrop-filter: blur(4px);
|
|
||||||
}
|
|
||||||
|
|
||||||
.content:after {
|
|
||||||
content: '';
|
|
||||||
position: absolute;
|
|
||||||
top: 0;
|
|
||||||
left: 0;
|
|
||||||
right: 0;
|
|
||||||
bottom: 0;
|
|
||||||
margin: auto;
|
|
||||||
background: #000;
|
|
||||||
opacity: 0.05;
|
|
||||||
border-radius: 10px;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.title {
|
.title {
|
||||||
@ -53,6 +33,6 @@
|
|||||||
width: 10px;
|
width: 10px;
|
||||||
height: 10px;
|
height: 10px;
|
||||||
border-radius: 100%;
|
border-radius: 100%;
|
||||||
border: 1px solid #fff;
|
border: 1px solid #b3b3b3;
|
||||||
margin-right: 8px;
|
margin-right: 8px;
|
||||||
}
|
}
|
||||||
|
@ -75,7 +75,12 @@ export default function WebsiteChart({
|
|||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
<div className="row">
|
<div className="row">
|
||||||
<PageviewsChart className="col" data={{ pageviews, uniques }} unit={unit}>
|
<PageviewsChart
|
||||||
|
className="col"
|
||||||
|
websiteId={websiteId}
|
||||||
|
data={{ pageviews, uniques }}
|
||||||
|
unit={unit}
|
||||||
|
>
|
||||||
<QuickButtons value={value} onChange={handleDateChange} />
|
<QuickButtons value={value} onChange={handleDateChange} />
|
||||||
</PageviewsChart>
|
</PageviewsChart>
|
||||||
</div>
|
</div>
|
||||||
|
Loading…
Reference in New Issue
Block a user