Compare commits

..

No commits in common. "4e99ee0c33849d7a0bddda193321aa09881cf917" and "e592c7044b5b95509eeffe6e85e6e2f526137b65" have entirely different histories.

8 changed files with 14 additions and 127 deletions

View File

@ -425,79 +425,5 @@
"television": "Television",
"radio": "Radio",
"field_recording": "Field Recording",
"scream": "Scream",
"sodeling": "Sodeling",
"chird": "Chird",
"change_ringing": "Change Ringing",
"shofar": "Shofar",
"liquid": "Liquid",
"splash": "Splash",
"slosh": "Slosh",
"squish": "Squish",
"drip": "Drip",
"pour": "Pour",
"trickle": "Trickle",
"gush": "Gush",
"fill": "Fill",
"spray": "Spray",
"pump": "Pump",
"stir": "Stir",
"boiling": "Boiling",
"sonar": "Sonar",
"arrow": "Arrow",
"whoosh": "Whoosh",
"thump": "Thump",
"thunk": "Thunk",
"electronic_tuner": "Electronic Tuner",
"effects_unit": "Effects Unit",
"chorus_effect": "Chorus Effect",
"basketball_bounce": "Basketball Bounce",
"bang": "Bang",
"slap": "Slap",
"whack": "Whack",
"smash": "Smash",
"breaking": "Breaking",
"bouncing": "Bouncing",
"whip": "Whip",
"flap": "Flap",
"scratch": "Scratch",
"scrape": "Scrape",
"rub": "Rub",
"roll": "Roll",
"crushing": "Crushing",
"crumpling": "Crumpling",
"tearing": "Tearing",
"beep": "Beep",
"ping": "Ping",
"ding": "Ding",
"clang": "Clang",
"squeal": "Squeal",
"creak": "Creak",
"rustle": "Rustle",
"whir": "Whir",
"clatter": "Clatter",
"sizzle": "Sizzle",
"clicking": "Clicking",
"clickety_clack": "Clickety Clack",
"rumble": "Rumble",
"plop": "Plop",
"hum": "Hum",
"zing": "Zing",
"boing": "Boing",
"crunch": "Crunch",
"sine_wave": "Sine Wave",
"harmonic": "Harmonic",
"chirp_tone": "Chirp Tone",
"pulse": "Pulse",
"inside": "Inside",
"outside": "Outside",
"reverberation": "Reverberation",
"echo": "Echo",
"noise": "Noise",
"mains_hum": "Mains Hum",
"distortion": "Distortion",
"sidetone": "Sidetone",
"cacophony": "Cacophony",
"throbbing": "Throbbing",
"vibration": "Vibration"
"scream": "Scream"
}

View File

@ -150,7 +150,7 @@ export default function SearchThumbnail({
.filter(
(item) => item !== undefined && !item.includes("-verified"),
)
.map((text) => getTranslatedLabel(text, searchResult.data.type))
.map((text) => getTranslatedLabel(text))
.sort()
.join(", ")
.replaceAll("-verified", "")}

View File

@ -34,7 +34,6 @@ const localeMap: Record<string, () => Promise<Locale>> = {
sk: () => import("date-fns/locale/sk").then((module) => module.sk),
"yue-Hant": () =>
import("date-fns/locale/zh-HK").then((module) => module.zhHK),
lt: () => import("date-fns/locale/lt").then((module) => module.lt),
th: () => import("date-fns/locale/th").then((module) => module.th),
ca: () => import("date-fns/locale/ca").then((module) => module.ca),
};

View File

@ -10,17 +10,14 @@ export const supportedLanguageKeys = [
"ro",
"nl",
"nb-NO",
"sv",
"zh-CN",
"yue-Hant",
"ja",
"vi",
"th",
"he",
"ru",
"tr",
"pl",
"lt",
"uk",
"cs",
"hu",

View File

@ -29,8 +29,6 @@ export type SearchSortType =
| "score_desc"
| "relevance";
export type EventType = "object" | "audio" | "manual";
export type SearchResult = {
id: string;
camera: string;
@ -56,7 +54,7 @@ export type SearchResult = {
box: number[];
area: number;
ratio: number;
type: EventType;
type: "object" | "audio" | "manual";
description?: string;
average_estimated_speed: number;
velocity_angle: number;

View File

@ -1,29 +1,11 @@
import i18n, { t } from "i18next";
import { initReactI18next } from "react-i18next";
import HttpBackend from "i18next-http-backend";
import { EventType } from "@/types/search";
export const getTranslatedLabel = (
label: string,
type: EventType = "object",
) => {
export const getTranslatedLabel = (label: string) => {
if (!label) return "";
if (type === "manual") return label;
const normalize = (s: string) =>
s
.trim()
.replace(/[-'\s]+/g, "_")
.replace(/__+/g, "_")
.replace(/^_+|_+$/g, "")
.toLowerCase();
const key = normalize(label);
const ns = type === "audio" ? "audio" : "objects";
return t(key, { ns });
return t(`${label.replace(/\s+/g, "_").toLowerCase()}`, { ns: "objects" });
};
i18n

View File

@ -11,7 +11,7 @@ import {
TooltipTrigger,
} from "@/components/ui/tooltip";
import { TooltipPortal } from "@radix-ui/react-tooltip";
import { EventType, SearchResult } from "@/types/search";
import { SearchResult } from "@/types/search";
import ImageLoadingIndicator from "@/components/indicators/ImageLoadingIndicator";
import useImageLoaded from "@/hooks/use-image-loaded";
import ActivityIndicator from "@/components/indicators/activity-indicator";
@ -110,8 +110,7 @@ export default function ExploreView({
key={label}
searchResults={filteredEvents}
isValidating={isValidating}
label={label}
labelType={filteredEvents[0]?.data?.type || "object"}
objectType={label}
setSearchDetail={setSearchDetail}
mutate={mutate}
setSimilaritySearch={setSimilaritySearch}
@ -123,8 +122,7 @@ export default function ExploreView({
}
type ThumbnailRowType = {
label: string;
labelType: EventType;
objectType: string;
searchResults?: SearchResult[];
isValidating: boolean;
setSearchDetail: (search: SearchResult | undefined) => void;
@ -134,8 +132,7 @@ type ThumbnailRowType = {
};
function ThumbnailRow({
label,
labelType,
objectType,
searchResults,
isValidating,
setSearchDetail,
@ -156,7 +153,7 @@ function ThumbnailRow({
return (
<div className="rounded-lg bg-background_alt p-2 md:px-4">
<div className="flex flex-row items-center text-lg smart-capitalize">
{getTranslatedLabel(label, labelType)}
{getTranslatedLabel(objectType)}
{searchResults && (
<span className="ml-3 text-sm text-secondary-foreground">
{t("trackedObjectsCount", {
@ -184,7 +181,7 @@ function ThumbnailRow({
))}
<div
className="flex cursor-pointer items-center justify-center"
onClick={() => handleSearch(label)}
onClick={() => handleSearch(objectType)}
>
<Tooltip>
<TooltipTrigger>
@ -195,9 +192,7 @@ function ThumbnailRow({
</TooltipTrigger>
<TooltipPortal>
<TooltipContent>
{t("exploreMore", {
label: getTranslatedLabel(label, labelType),
})}
{t("exploreMore", { label: getTranslatedLabel(objectType) })}
</TooltipContent>
</TooltipPortal>
</Tooltip>

View File

@ -100,12 +100,7 @@ export default function CameraSettingsView({
const alertsLabels = useMemo(() => {
return cameraConfig?.review.alerts.labels
? cameraConfig.review.alerts.labels
.map((label) =>
getTranslatedLabel(
label,
cameraConfig?.audio?.listen?.includes(label) ? "audio" : "object",
),
)
.map((label) => getTranslatedLabel(label))
.join(", ")
: "";
}, [cameraConfig]);
@ -113,12 +108,7 @@ export default function CameraSettingsView({
const detectionsLabels = useMemo(() => {
return cameraConfig?.review.detections.labels
? cameraConfig.review.detections.labels
.map((label) =>
getTranslatedLabel(
label,
cameraConfig?.audio?.listen?.includes(label) ? "audio" : "object",
),
)
.map((label) => getTranslatedLabel(label))
.join(", ")
: "";
}, [cameraConfig]);