Skip to content

Commit

Permalink
feat: add coundown timer
Browse files Browse the repository at this point in the history
  • Loading branch information
leggetter committed Aug 18, 2024
1 parent 85009be commit fa25397
Show file tree
Hide file tree
Showing 5 changed files with 60 additions and 4 deletions.
5 changes: 4 additions & 1 deletion .env.example
Original file line number Diff line number Diff line change
Expand Up @@ -14,4 +14,7 @@ NEXT_PUBLIC_STREAM_API_KEY=
STREAM_API_SECRET=

# supabase | stream
VIDEO_STORAGE_PLATFORM=supabase
VIDEO_STORAGE_PLATFORM=supabase

# Maximum video length in seconds
NEXT_PUBLIC_VIDEO_MAX_LENGTH=60
1 change: 0 additions & 1 deletion app/vlogs/[username]/[vlog_id]/page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -99,7 +99,6 @@ const getVlog = async (vlogId: string): Promise<VlogItem | null> => {
? await getVlogFromStream(vlogId)
: await getVlogFromSupabase(vlogId);

console.log({ vlog });
return vlog;
};

Expand Down
1 change: 0 additions & 1 deletion app/vlogs/new/page.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
import { cookies } from "next/headers";
import { createClient } from "@/utils/supabase/server";
import { redirect } from "next/navigation";
import RecordVlog from "@/components/RecordVlog";
Expand Down
48 changes: 47 additions & 1 deletion components/RecordVlog.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ import { PiRecordBold } from "react-icons/pi";
import "@stream-io/video-react-sdk/dist/css/styles.css";
import Button from "./Button";
import { createClient } from "@/utils/supabase/client";
import Config from "@/utils/config";

export default function RecordVideo({
userId,
Expand Down Expand Up @@ -168,6 +169,47 @@ export const UILayout = ({
}) => {
const { useCallCallingState } = useCallStateHooks();
const callingState: CallingState = useCallCallingState();
const [timeLeft, setTimeLeft] = useState<number>(Config.VIDEO_MAX_LENGTH);
const [timerRunning, setTimerRunning] = useState(false);
const call = useCall();

useEffect(() => {
if (timerRunning === false) {
return;
}
const interval = setInterval(() => {
setTimeLeft((prev) => prev - 1);
}, 1000);

return () => clearInterval(interval);
}, [timerRunning]);

useEffect(() => {
if (call) {
const handler = async () => {
console.log("in handler");
setTimerRunning(true);
};
call.on("call.recording_started", handler);
return () => {
call.off("call.recording_started", handler);
};
}
}, [call]);

useEffect(() => {
if (timeLeft <= 0) {
setTimerRunning(false);
const stopCall = async () => {
await onRecordingStopping();
await call
?.stopRecording()
.catch((e) => console.error(`Failed to stop`, e));
};
stopCall();
}
}, [timeLeft]);

if (
callingState !== CallingState.JOINED &&
callingState !== CallingState.LEFT
Expand All @@ -178,8 +220,12 @@ export const UILayout = ({
}

return (
<StreamTheme className="flex flex-col w-full">
<StreamTheme className="flex flex-col w-full relative">
<SpeakerLayout participantsBarPosition="bottom" />
<div className="text-center text-sm">
Video time remaining: {timeLeft} second
{timeLeft > 0 && "s"}
</div>
<div className="str-video__call-controls">
{/* <RecordCallButton /> */}
<CustomRecordCallButton
Expand Down
9 changes: 9 additions & 0 deletions utils/config.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
const VIDEO_MAX_LENGTH = parseInt(
process.env.NEXT_PUBLIC_VIDEO_MAX_LENGTH + ""
);

const Config = {
VIDEO_MAX_LENGTH: isNaN(VIDEO_MAX_LENGTH) == false ? VIDEO_MAX_LENGTH : 60,
};

export default Config;

0 comments on commit fa25397

Please sign in to comment.