|
|
@ -1,5 +1,4 @@
|
|
|
|
import { Tooltip } from "@mui/joy";
|
|
|
|
import { Tooltip } from "@mui/joy";
|
|
|
|
import clsx from "clsx";
|
|
|
|
|
|
|
|
import dayjs from "dayjs";
|
|
|
|
import dayjs from "dayjs";
|
|
|
|
import { countBy } from "lodash-es";
|
|
|
|
import { countBy } from "lodash-es";
|
|
|
|
import { CheckCircleIcon, ChevronDownIcon, ChevronUpIcon, Code2Icon, LinkIcon, ListTodoIcon } from "lucide-react";
|
|
|
|
import { CheckCircleIcon, ChevronDownIcon, ChevronUpIcon, Code2Icon, LinkIcon, ListTodoIcon } from "lucide-react";
|
|
|
@ -8,6 +7,7 @@ import useAsyncEffect from "@/hooks/useAsyncEffect";
|
|
|
|
import i18n from "@/i18n";
|
|
|
|
import i18n from "@/i18n";
|
|
|
|
import { useMemoFilterStore, useUserStatsStore } from "@/store/v1";
|
|
|
|
import { useMemoFilterStore, useUserStatsStore } from "@/store/v1";
|
|
|
|
import { UserStats_MemoTypeStats } from "@/types/proto/api/v1/user_service";
|
|
|
|
import { UserStats_MemoTypeStats } from "@/types/proto/api/v1/user_service";
|
|
|
|
|
|
|
|
import { cn } from "@/utils";
|
|
|
|
import { useTranslate } from "@/utils/i18n";
|
|
|
|
import { useTranslate } from "@/utils/i18n";
|
|
|
|
import ActivityCalendar from "./ActivityCalendar";
|
|
|
|
import ActivityCalendar from "./ActivityCalendar";
|
|
|
|
|
|
|
|
|
|
|
@ -42,7 +42,7 @@ const StatisticsView = () => {
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
return (
|
|
|
|
return (
|
|
|
|
<div className="group w-full mt-2 py-2 space-y-1 text-gray-500 dark:text-gray-400">
|
|
|
|
<div className="group w-full mt-4 space-y-1 text-gray-500 dark:text-gray-400">
|
|
|
|
<div className="w-full mb-1 flex flex-row justify-between items-center gap-1">
|
|
|
|
<div className="w-full mb-1 flex flex-row justify-between items-center gap-1">
|
|
|
|
<div className="relative text-sm font-medium inline-flex flex-row items-center w-auto dark:text-gray-400 truncate">
|
|
|
|
<div className="relative text-sm font-medium inline-flex flex-row items-center w-auto dark:text-gray-400 truncate">
|
|
|
|
<span className="truncate">
|
|
|
|
<span className="truncate">
|
|
|
@ -74,7 +74,7 @@ const StatisticsView = () => {
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div className="pt-1 w-full flex flex-row justify-start items-center gap-x-2 gap-y-1 flex-wrap">
|
|
|
|
<div className="pt-1 w-full flex flex-row justify-start items-center gap-x-2 gap-y-1 flex-wrap">
|
|
|
|
<div
|
|
|
|
<div
|
|
|
|
className={clsx("w-auto border dark:border-zinc-800 pl-1 pr-1.5 rounded-md flex justify-between items-center")}
|
|
|
|
className={cn("w-auto border dark:border-zinc-800 pl-1.5 pr-2 py-0.5 rounded-md flex justify-between items-center")}
|
|
|
|
onClick={() => memoFilterStore.addFilter({ factor: "property.hasLink", value: "" })}
|
|
|
|
onClick={() => memoFilterStore.addFilter({ factor: "property.hasLink", value: "" })}
|
|
|
|
>
|
|
|
|
>
|
|
|
|
<div className="w-auto flex justify-start items-center mr-1">
|
|
|
|
<div className="w-auto flex justify-start items-center mr-1">
|
|
|
@ -84,7 +84,7 @@ const StatisticsView = () => {
|
|
|
|
<span className="text-sm truncate">{memoTypeStats.linkCount}</span>
|
|
|
|
<span className="text-sm truncate">{memoTypeStats.linkCount}</span>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div
|
|
|
|
<div
|
|
|
|
className={clsx("w-auto border dark:border-zinc-800 pl-1 pr-1.5 rounded-md flex justify-between items-center")}
|
|
|
|
className={cn("w-auto border dark:border-zinc-800 pl-1.5 pr-2 py-0.5 rounded-md flex justify-between items-center")}
|
|
|
|
onClick={() => memoFilterStore.addFilter({ factor: "property.hasTaskList", value: "" })}
|
|
|
|
onClick={() => memoFilterStore.addFilter({ factor: "property.hasTaskList", value: "" })}
|
|
|
|
>
|
|
|
|
>
|
|
|
|
<div className="w-auto flex justify-start items-center mr-1">
|
|
|
|
<div className="w-auto flex justify-start items-center mr-1">
|
|
|
@ -104,7 +104,7 @@ const StatisticsView = () => {
|
|
|
|
)}
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div
|
|
|
|
<div
|
|
|
|
className={clsx("w-auto border dark:border-zinc-800 pl-1 pr-1.5 rounded-md flex justify-between items-center")}
|
|
|
|
className={cn("w-auto border dark:border-zinc-800 pl-1.5 pr-2 py-0.5 rounded-md flex justify-between items-center")}
|
|
|
|
onClick={() => memoFilterStore.addFilter({ factor: "property.hasCode", value: "" })}
|
|
|
|
onClick={() => memoFilterStore.addFilter({ factor: "property.hasCode", value: "" })}
|
|
|
|
>
|
|
|
|
>
|
|
|
|
<div className="w-auto flex justify-start items-center mr-1">
|
|
|
|
<div className="w-auto flex justify-start items-center mr-1">
|
|
|
|