mirror of
https://github.com/blakeblackshear/frigate.git
synced 2024-11-26 19:06:11 +01:00
64988c9be0
* Break out live page * Improving layouts and add chip component * Improve default camera player sizing * Improve live updating * Cleanup and fit figma * Use fixed height * Masonry layout * Fix stuff * Don't force heights * Adjust scaling * Cleanup * remove sidebar (#9731) * remove sidebar * keep sidebar on mobile for now and add icons * Fix revalidation * Cleanup * Cleanup width * Add chips for activity on cameras * Remove dashboard from header * Use Inter font (#9735) * Show still image when no activity is occurring * remove unused search params * add playing check for webrtc * Don't use grid at all for single column * Fix height on mobile * a few style updates to better match figma (#9745) * Remove active objects when they become stationary * Move to sidebar only and make settings separate component * Fix layout * Animate visibility of chips * Sidebar is full screen * Fix tall aspect ratio cameras * Fix complicated aspect logic * remove * Adjust thumbnail aspect and add text * margin on single column layout * Smaller event thumb text * Simplify basic image view * Only show the red dot when camera is recording * Improve typing for camera toggles * animate chips with react-transition-group (#9763) * don't flash when going to still image * revalidate * tooltips and active tracking outline (#9766) * tooltips * fix tooltip provider and add active tracking outline * remove unused icon * remove figma comment * Get live mode working for jsmpeg * add small gradient below timeago on event thumbnails (#9767) * Create live mode hook and make sure jsmpeg can be used * Enforce env var * Use print * Remove unstable * Add tooltips to thumbnails * Put back vite * Format * Update web/src/components/player/JSMpegPlayer.tsx --------- Co-authored-by: Josh Hawkins <32435876+hawkeye217@users.noreply.github.com> Co-authored-by: Blake Blackshear <blake@frigate.video>
39 lines
857 B
TypeScript
39 lines
857 B
TypeScript
import { ReactNode, useRef } from "react";
|
|
import { CSSTransition } from "react-transition-group";
|
|
|
|
type ChipProps = {
|
|
className?: string;
|
|
children?: ReactNode[];
|
|
in?: boolean;
|
|
};
|
|
|
|
export default function Chip({
|
|
className,
|
|
children,
|
|
in: inProp = true,
|
|
}: ChipProps) {
|
|
const nodeRef = useRef(null);
|
|
|
|
return (
|
|
<CSSTransition
|
|
in={inProp}
|
|
nodeRef={nodeRef}
|
|
timeout={500}
|
|
classNames={{
|
|
enter: "opacity-0",
|
|
enterActive: "opacity-100 transition-opacity duration-500 ease-in-out",
|
|
exit: "opacity-100",
|
|
exitActive: "opacity-0 transition-opacity duration-500 ease-in-out",
|
|
}}
|
|
unmountOnExit
|
|
>
|
|
<div
|
|
ref={nodeRef}
|
|
className={`flex px-2 py-1.5 rounded-2xl items-center z-10 ${className}`}
|
|
>
|
|
{children}
|
|
</div>
|
|
</CSSTransition>
|
|
);
|
|
}
|