mirror of
https://github.com/blakeblackshear/frigate.git
synced 2025-12-06 13:34:13 +03:00
* Remove tracked object update resets * Adjust face blur reduction * Add space for config editor buttons * Slight adjustment * Fix double thats * update icons --------- Co-authored-by: Josh Hawkins <32435876+hawkeye217@users.noreply.github.com>
180 lines
5.3 KiB
TypeScript
180 lines
5.3 KiB
TypeScript
import { IconName } from "@/components/icons/IconPicker";
|
|
import { FrigateConfig } from "@/types/frigateConfig";
|
|
import { BsPersonWalking } from "react-icons/bs";
|
|
import {
|
|
FaAmazon,
|
|
FaBicycle,
|
|
FaBus,
|
|
FaCarSide,
|
|
FaCat,
|
|
FaCheckCircle,
|
|
FaDhl,
|
|
FaDog,
|
|
FaFedex,
|
|
FaFire,
|
|
FaFootballBall,
|
|
FaHockeyPuck,
|
|
FaHorse,
|
|
FaMotorcycle,
|
|
FaMouse,
|
|
FaRegTrashAlt,
|
|
FaUmbrella,
|
|
FaUps,
|
|
FaUsps,
|
|
} from "react-icons/fa";
|
|
import {
|
|
GiDeer,
|
|
GiFox,
|
|
GiGoat,
|
|
GiKangaroo,
|
|
GiPolarBear,
|
|
GiPostStamp,
|
|
GiRabbit,
|
|
GiRaccoonHead,
|
|
GiSailboat,
|
|
GiSquirrel,
|
|
} from "react-icons/gi";
|
|
import { LuBox, LuLassoSelect, LuScanBarcode } from "react-icons/lu";
|
|
import * as LuIcons from "react-icons/lu";
|
|
import { MdRecordVoiceOver } from "react-icons/md";
|
|
import { PiBirdFill } from "react-icons/pi";
|
|
|
|
export function getAttributeLabels(config?: FrigateConfig) {
|
|
if (!config) {
|
|
return [];
|
|
}
|
|
|
|
const labels = new Set();
|
|
|
|
Object.values(config.model.attributes_map).forEach((values) =>
|
|
values.forEach((label) => labels.add(label)),
|
|
);
|
|
return [...labels];
|
|
}
|
|
|
|
export function isValidIconName(value: string): value is IconName {
|
|
return Object.keys(LuIcons).includes(value as IconName);
|
|
}
|
|
|
|
export function getIconForLabel(label: string, className?: string) {
|
|
if (label.endsWith("-verified")) {
|
|
return getVerifiedIcon(label, className);
|
|
} else if (label.endsWith("-plate")) {
|
|
return getRecognizedPlateIcon(label, className);
|
|
}
|
|
|
|
switch (label) {
|
|
// objects
|
|
case "bear":
|
|
return <GiPolarBear key={label} className={className} />;
|
|
case "bicycle":
|
|
return <FaBicycle key={label} className={className} />;
|
|
case "bird":
|
|
return <PiBirdFill key={label} className={className} />;
|
|
case "boat":
|
|
return <GiSailboat key={label} className={className} />;
|
|
case "bus":
|
|
case "school_bus":
|
|
return <FaBus key={label} className={className} />;
|
|
case "car":
|
|
case "vehicle":
|
|
return <FaCarSide key={label} className={className} />;
|
|
case "cat":
|
|
return <FaCat key={label} className={className} />;
|
|
case "deer":
|
|
return <GiDeer key={label} className={className} />;
|
|
case "animal":
|
|
case "bark":
|
|
case "dog":
|
|
return <FaDog key={label} className={className} />;
|
|
case "fox":
|
|
return <GiFox key={label} className={className} />;
|
|
case "goat":
|
|
return <GiGoat key={label} className={className} />;
|
|
case "horse":
|
|
return <FaHorse key={label} className={className} />;
|
|
case "kangaroo":
|
|
return <GiKangaroo key={label} className={className} />;
|
|
case "license_plate":
|
|
return <LuScanBarcode key={label} className={className} />;
|
|
case "motorcycle":
|
|
return <FaMotorcycle key={label} className={className} />;
|
|
case "mouse":
|
|
return <FaMouse key={label} className={className} />;
|
|
case "package":
|
|
return <LuBox key={label} className={className} />;
|
|
case "person":
|
|
return <BsPersonWalking key={label} className={className} />;
|
|
case "rabbit":
|
|
return <GiRabbit key={label} className={className} />;
|
|
case "raccoon":
|
|
return <GiRaccoonHead key={label} className={className} />;
|
|
case "robot_lawnmower":
|
|
return <FaHockeyPuck key={label} className={className} />;
|
|
case "sports_ball":
|
|
return <FaFootballBall key={label} className={className} />;
|
|
case "skunk":
|
|
return <GiSquirrel key={label} className={className} />;
|
|
case "squirrel":
|
|
return <LuIcons.LuSquirrel key={label} className={className} />;
|
|
case "umbrella":
|
|
return <FaUmbrella key={label} className={className} />;
|
|
case "waste_bin":
|
|
return <FaRegTrashAlt key={label} className={className} />;
|
|
// audio
|
|
case "crying":
|
|
case "laughter":
|
|
case "scream":
|
|
case "speech":
|
|
case "yell":
|
|
return <MdRecordVoiceOver key={label} className={className} />;
|
|
case "fire_alarm":
|
|
return <FaFire key={label} className={className} />;
|
|
// sub labels
|
|
case "amazon":
|
|
return <FaAmazon key={label} className={className} />;
|
|
case "an_post":
|
|
case "canada_post":
|
|
case "dpd":
|
|
case "gls":
|
|
case "nzpost":
|
|
case "postnl":
|
|
case "postnord":
|
|
case "purolator":
|
|
case "royal_mail":
|
|
return <GiPostStamp key={label} className={className} />;
|
|
case "dhl":
|
|
return <FaDhl key={label} className={className} />;
|
|
case "fedex":
|
|
return <FaFedex key={label} className={className} />;
|
|
case "ups":
|
|
return <FaUps key={label} className={className} />;
|
|
case "usps":
|
|
return <FaUsps key={label} className={className} />;
|
|
default:
|
|
return <LuLassoSelect key={label} className={className} />;
|
|
}
|
|
}
|
|
|
|
function getVerifiedIcon(label: string, className?: string) {
|
|
const simpleLabel = label.substring(0, label.lastIndexOf("-"));
|
|
|
|
return (
|
|
<div key={label} className="flex items-center">
|
|
{getIconForLabel(simpleLabel, className)}
|
|
<FaCheckCircle className="absolute size-2 translate-x-[80%] translate-y-3/4" />
|
|
</div>
|
|
);
|
|
}
|
|
|
|
function getRecognizedPlateIcon(label: string, className?: string) {
|
|
const simpleLabel = label.substring(0, label.lastIndexOf("-"));
|
|
|
|
return (
|
|
<div key={label} className="flex items-center">
|
|
{getIconForLabel(simpleLabel, className)}
|
|
<LuScanBarcode className="absolute size-2.5 translate-x-[50%] translate-y-3/4" />
|
|
</div>
|
|
);
|
|
}
|