|
|
@ -22,6 +22,16 @@ import {
|
|
|
|
import TabPane from "antd/es/tabs/TabPane";
|
|
|
|
import TabPane from "antd/es/tabs/TabPane";
|
|
|
|
// @ts-ignore
|
|
|
|
// @ts-ignore
|
|
|
|
import IconSearch from "../../assets/searchIcon.png";
|
|
|
|
import IconSearch from "../../assets/searchIcon.png";
|
|
|
|
|
|
|
|
import {
|
|
|
|
|
|
|
|
CartesianGrid,
|
|
|
|
|
|
|
|
Legend,
|
|
|
|
|
|
|
|
Line,
|
|
|
|
|
|
|
|
LineChart,
|
|
|
|
|
|
|
|
ResponsiveContainer,
|
|
|
|
|
|
|
|
Tooltip,
|
|
|
|
|
|
|
|
XAxis,
|
|
|
|
|
|
|
|
YAxis,
|
|
|
|
|
|
|
|
} from "recharts";
|
|
|
|
|
|
|
|
|
|
|
|
const Stat = () => {
|
|
|
|
const Stat = () => {
|
|
|
|
const now = dayjs();
|
|
|
|
const now = dayjs();
|
|
|
@ -37,6 +47,8 @@ const Stat = () => {
|
|
|
|
const [startDate, setStartDate] = useState(start_date);
|
|
|
|
const [startDate, setStartDate] = useState(start_date);
|
|
|
|
const [endDate, setEndDate] = useState(end_date);
|
|
|
|
const [endDate, setEndDate] = useState(end_date);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const [forSalary, setForSalary] = useState(true);
|
|
|
|
|
|
|
|
|
|
|
|
const teamData = useTeamData({});
|
|
|
|
const teamData = useTeamData({});
|
|
|
|
const teamOptions: { label: string; value: any }[] | undefined =
|
|
|
|
const teamOptions: { label: string; value: any }[] | undefined =
|
|
|
|
teamData?.data?.map((item) => ({
|
|
|
|
teamData?.data?.map((item) => ({
|
|
|
@ -84,14 +96,21 @@ const Stat = () => {
|
|
|
|
|
|
|
|
|
|
|
|
setStartDate(`${yearStart}-${monthStart}-01 00:00:00`);
|
|
|
|
setStartDate(`${yearStart}-${monthStart}-01 00:00:00`);
|
|
|
|
setEndDate(`${yearEnd}-${monthEnd}-01 00:00:00`);
|
|
|
|
setEndDate(`${yearEnd}-${monthEnd}-01 00:00:00`);
|
|
|
|
|
|
|
|
setForSalary(true);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const clearDatePcker = () => {
|
|
|
|
|
|
|
|
setStartDate("");
|
|
|
|
|
|
|
|
setEndDate("");
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
const { data, refetch, isLoading } = useStatsData({
|
|
|
|
const { data, refetch, isLoading } = useStatsData({
|
|
|
|
search: search,
|
|
|
|
search: search,
|
|
|
|
team: team,
|
|
|
|
team: team,
|
|
|
|
start_date: startDate,
|
|
|
|
start_date: startDate,
|
|
|
|
end_date: endDate,
|
|
|
|
end_date: endDate,
|
|
|
|
|
|
|
|
for_salary: forSalary,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
interface DataType {
|
|
|
|
interface DataType {
|
|
|
|
data?: TStatTeam[];
|
|
|
|
data?: TStatTeam[];
|
|
|
@ -118,6 +137,83 @@ const Stat = () => {
|
|
|
|
}, 1000);
|
|
|
|
}, 1000);
|
|
|
|
};
|
|
|
|
};
|
|
|
|
const theme = localStorage.getItem("theme") === "true" ? true : false;
|
|
|
|
const theme = localStorage.getItem("theme") === "true" ? true : false;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// const chartData = [
|
|
|
|
|
|
|
|
// {
|
|
|
|
|
|
|
|
// date: "2024-12-01",
|
|
|
|
|
|
|
|
// ABM: { points: 4500, count: 20 },
|
|
|
|
|
|
|
|
// ZNX: { points: 2500, count: 18 },
|
|
|
|
|
|
|
|
// TYP: { points: 3900, count: 24 },
|
|
|
|
|
|
|
|
// LMO: { points: 3100, count: 16 },
|
|
|
|
|
|
|
|
// QWE: { points: 2800, count: 21 },
|
|
|
|
|
|
|
|
// RST: { points: 4400, count: 19 },
|
|
|
|
|
|
|
|
// UVX: { points: 3950, count: 22 },
|
|
|
|
|
|
|
|
// WYZ: { points: 4100, count: 20 },
|
|
|
|
|
|
|
|
// ERT: { points: 3700, count: 17 },
|
|
|
|
|
|
|
|
// KLM: { points: 4200, count: 25 },
|
|
|
|
|
|
|
|
// LBS: { points: 1200, count: 25 },
|
|
|
|
|
|
|
|
// },
|
|
|
|
|
|
|
|
// {
|
|
|
|
|
|
|
|
// date: "2024-12-02",
|
|
|
|
|
|
|
|
// ABM: { points: 4600, count: 21 },
|
|
|
|
|
|
|
|
// ZNX: { points: 2400, count: 17 },
|
|
|
|
|
|
|
|
// TYP: { points: 3850, count: 23 },
|
|
|
|
|
|
|
|
// LMO: { points: 3200, count: 15 },
|
|
|
|
|
|
|
|
// QWE: { points: 2750, count: 20 },
|
|
|
|
|
|
|
|
// RST: { points: 4450, count: 18 },
|
|
|
|
|
|
|
|
// UVX: { points: 4000, count: 23 },
|
|
|
|
|
|
|
|
// WYZ: { points: 4200, count: 19 },
|
|
|
|
|
|
|
|
// ERT: { points: 3750, count: 16 },
|
|
|
|
|
|
|
|
// KLM: { points: 4250, count: 24 },
|
|
|
|
|
|
|
|
// LBS: { points: 1250, count: 26 },
|
|
|
|
|
|
|
|
// },
|
|
|
|
|
|
|
|
// {
|
|
|
|
|
|
|
|
// date: "2024-12-03",
|
|
|
|
|
|
|
|
// ABM: { points: 4550, count: 19 },
|
|
|
|
|
|
|
|
// ZNX: { points: 2550, count: 19 },
|
|
|
|
|
|
|
|
// TYP: { points: 3950, count: 25 },
|
|
|
|
|
|
|
|
// LMO: { points: 3150, count: 17 },
|
|
|
|
|
|
|
|
// QWE: { points: 2850, count: 22 },
|
|
|
|
|
|
|
|
// RST: { points: 4500, count: 20 },
|
|
|
|
|
|
|
|
// UVX: { points: 3900, count: 21 },
|
|
|
|
|
|
|
|
// WYZ: { points: 4300, count: 21 },
|
|
|
|
|
|
|
|
// ERT: { points: 3800, count: 18 },
|
|
|
|
|
|
|
|
// KLM: { points: 4300, count: 26 },
|
|
|
|
|
|
|
|
// LBS: { points: 1300, count: 27 },
|
|
|
|
|
|
|
|
// },
|
|
|
|
|
|
|
|
// ];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// const lines = [
|
|
|
|
|
|
|
|
// { key: "ABM.points", color: "#FF5733" }, // orange-red
|
|
|
|
|
|
|
|
// { key: "ZNX.points", color: "#00b822" }, // lime-green
|
|
|
|
|
|
|
|
// { key: "TYP.points", color: "#5733FF" }, // blue-purple
|
|
|
|
|
|
|
|
// { key: "LMO.points", color: "#FFC300" }, // gold
|
|
|
|
|
|
|
|
// { key: "QWE.points", color: "#009790" }, // turquoise
|
|
|
|
|
|
|
|
// { key: "RST.points", color: "#FF33A1" }, // hot pink
|
|
|
|
|
|
|
|
// { key: "UVX.points", color: "#8D33FF" }, // violet
|
|
|
|
|
|
|
|
// { key: "WYZ.points", color: "#FF8D33" }, // orange
|
|
|
|
|
|
|
|
// { key: "ERT.points", color: "#33A1FF" }, // sky blue
|
|
|
|
|
|
|
|
// { key: "KLM.points", color: "#4a8a01" }, // light green
|
|
|
|
|
|
|
|
// ];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// console.log(chartData, );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// const predefinedColors = ["#FF5733", "#00b822"];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// function updateLines(chartData: any, predefinedColors: any) {
|
|
|
|
|
|
|
|
// const keys = Object.keys(chartData[0]).filter((key) => key !== "date");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// const newLines = keys.map((key, index) => {
|
|
|
|
|
|
|
|
// const color = predefinedColors[index % predefinedColors.length]; // Ranglarni aylantirib foydalanadi
|
|
|
|
|
|
|
|
// return { key: `${key}.points`, color, name: `${key}` };
|
|
|
|
|
|
|
|
// });
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// return newLines;
|
|
|
|
|
|
|
|
// }
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// lines massivini yangilash
|
|
|
|
|
|
|
|
// const lines = updateLines(chartData, predefinedColors);
|
|
|
|
|
|
|
|
|
|
|
|
return (
|
|
|
|
return (
|
|
|
|
<div>
|
|
|
|
<div>
|
|
|
|
<div
|
|
|
|
<div
|
|
|
@ -183,6 +279,32 @@ const Stat = () => {
|
|
|
|
<Button type="primary" onClick={(e) => handleSave("")}>
|
|
|
|
<Button type="primary" onClick={(e) => handleSave("")}>
|
|
|
|
Save as file
|
|
|
|
Save as file
|
|
|
|
</Button>
|
|
|
|
</Button>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
{/* <ResponsiveContainer width="100%" height={400}>
|
|
|
|
|
|
|
|
<LineChart
|
|
|
|
|
|
|
|
width={800}
|
|
|
|
|
|
|
|
height={400}
|
|
|
|
|
|
|
|
data={chartData}
|
|
|
|
|
|
|
|
margin={{ top: 20, right: 30, left: 20, bottom: 10 }}
|
|
|
|
|
|
|
|
>
|
|
|
|
|
|
|
|
<CartesianGrid strokeDasharray="3 3" />
|
|
|
|
|
|
|
|
<XAxis dataKey="date" />
|
|
|
|
|
|
|
|
<YAxis />
|
|
|
|
|
|
|
|
<Tooltip />
|
|
|
|
|
|
|
|
<Legend />
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
{lines.map((line, index) => (
|
|
|
|
|
|
|
|
<Line
|
|
|
|
|
|
|
|
key={index}
|
|
|
|
|
|
|
|
type="linear"
|
|
|
|
|
|
|
|
dataKey={line.key}
|
|
|
|
|
|
|
|
name={line.name}
|
|
|
|
|
|
|
|
stroke={line.color}
|
|
|
|
|
|
|
|
activeDot={{ r: 7 }}
|
|
|
|
|
|
|
|
/>
|
|
|
|
|
|
|
|
))}
|
|
|
|
|
|
|
|
</LineChart>
|
|
|
|
|
|
|
|
</ResponsiveContainer> */}
|
|
|
|
</TabPane>
|
|
|
|
</TabPane>
|
|
|
|
</Tabs>
|
|
|
|
</Tabs>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|