mirror of
https://github.com/blakeblackshear/frigate.git
synced 2025-12-21 20:46:43 +03:00
* Translation module init
* Add more i18n keys
* fix: fix string wrong
* refactor: use namespace translation file
* chore: add more translation key
* fix: fix some page name error
* refactor: change Trans tag for t function
* chore: fix some key not work
* chore: fix SearchFilterDialog i18n key error
Co-authored-by: Josh Hawkins <32435876+hawkeye217@users.noreply.github.com>
* chore: fix en i18n file filter missing some keys
* chore: add some i18n keys
* chore: add more i18n keys again
* feat: add search page i18n
* feat: add explore model i18n keys
* Update web/src/components/menu/GeneralSettings.tsx
Co-authored-by: Josh Hawkins <32435876+hawkeye217@users.noreply.github.com>
* Update web/src/components/menu/GeneralSettings.tsx
Co-authored-by: Josh Hawkins <32435876+hawkeye217@users.noreply.github.com>
* Update web/src/components/menu/GeneralSettings.tsx
Co-authored-by: Josh Hawkins <32435876+hawkeye217@users.noreply.github.com>
* feat: add more live i18n keys
* feat: add more search setting i18n keys
* fix: remove some comment
* fix: fix some setting page url error
* Update web/src/views/settings/SearchSettingsView.tsx
Co-authored-by: Josh Hawkins <32435876+hawkeye217@users.noreply.github.com>
* fix: add system missing keys
* fix: update password update i18n keys
* chore: remove outdate translation.json file
* fix: fix exploreSettings error
* chore: add object setting i18n keys
* Update web/src/views/recording/RecordingView.tsx
Co-authored-by: Josh Hawkins <32435876+hawkeye217@users.noreply.github.com>
* Update web/public/locales/en/components/filter.json
Co-authored-by: Josh Hawkins <32435876+hawkeye217@users.noreply.github.com>
* Update web/src/components/overlay/ExportDialog.tsx
Co-authored-by: Josh Hawkins <32435876+hawkeye217@users.noreply.github.com>
* feat: add more i18n keys
* fix: fix motionDetectionTuner html node
* feat: add more page i18n keys
* fix: cameraStream i18n keys error
* feat: add Player i18n keys
* feat: add more toast i18n keys
* feat: change explore setting name
* feat: add more document title i18n keys
* feat: add more search i18n keys
* fix: fix accessDenied i18n keys error
* chore: add objectType i18n
* chore: add inputWithTags i18n
* chore: add SearchFilterDialog i18n
* Update web/src/views/settings/ObjectSettingsView.tsx
Co-authored-by: Josh Hawkins <32435876+hawkeye217@users.noreply.github.com>
* Update web/src/views/settings/ObjectSettingsView.tsx
Co-authored-by: Josh Hawkins <32435876+hawkeye217@users.noreply.github.com>
* Update web/src/views/settings/ObjectSettingsView.tsx
Co-authored-by: Josh Hawkins <32435876+hawkeye217@users.noreply.github.com>
* Update web/src/views/settings/ObjectSettingsView.tsx
Co-authored-by: Josh Hawkins <32435876+hawkeye217@users.noreply.github.com>
* Update web/src/views/settings/ObjectSettingsView.tsx
Co-authored-by: Josh Hawkins <32435876+hawkeye217@users.noreply.github.com>
* chore: add some missing i18n keys
* chore: remove most import { t } from "i18next";
---------
Co-authored-by: Josh Hawkins <32435876+hawkeye217@users.noreply.github.com>
59 lines
1.6 KiB
TypeScript
59 lines
1.6 KiB
TypeScript
import { ReviewSegment } from "@/types/review";
|
|
import { Button } from "../ui/button";
|
|
import { LuRefreshCcw } from "react-icons/lu";
|
|
import { MutableRefObject, useMemo } from "react";
|
|
import { cn } from "@/lib/utils";
|
|
import { useTranslation } from "react-i18next";
|
|
|
|
type NewReviewDataProps = {
|
|
className: string;
|
|
contentRef: MutableRefObject<HTMLDivElement | null>;
|
|
reviewItems?: ReviewSegment[] | null;
|
|
itemsToReview?: number;
|
|
pullLatestData: () => void;
|
|
};
|
|
export default function NewReviewData({
|
|
className,
|
|
contentRef,
|
|
reviewItems,
|
|
itemsToReview,
|
|
pullLatestData,
|
|
}: NewReviewDataProps) {
|
|
const { t } = useTranslation(["views/events"]);
|
|
const hasUpdate = useMemo(() => {
|
|
if (!reviewItems || !itemsToReview) {
|
|
return false;
|
|
}
|
|
|
|
return reviewItems.length < itemsToReview;
|
|
}, [reviewItems, itemsToReview]);
|
|
|
|
return (
|
|
<div className={className}>
|
|
<div className="pointer-events-auto mr-[65px] mt-8 flex items-center justify-center md:mr-[115px]">
|
|
<Button
|
|
className={cn(
|
|
hasUpdate
|
|
? "duration-500 animate-in slide-in-from-top"
|
|
: "invisible",
|
|
"mx-auto bg-gray-400 text-center text-white",
|
|
)}
|
|
aria-label={t("newReviewItems.label")}
|
|
onClick={() => {
|
|
pullLatestData();
|
|
if (contentRef.current) {
|
|
contentRef.current.scrollTo({
|
|
top: 0,
|
|
behavior: "smooth",
|
|
});
|
|
}
|
|
}}
|
|
>
|
|
<LuRefreshCcw className="mr-2 h-4 w-4" />
|
|
{t("newReviewItems.button")}
|
|
</Button>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|