recorder extract styles, use server waveform

This commit is contained in:
Sara
2023-10-09 15:53:21 +02:00
parent 2cf61b191f
commit f65813ec60
2 changed files with 60 additions and 38 deletions

View File

@@ -0,0 +1,30 @@
export const waveSurferStyles = {
playerSettings: {
waveColor: "#777",
progressColor: "#222",
cursorColor: "OrangeRed",
},
playerStyle: {
cursor: "pointer",
backgroundColor: "RGB(240 240 240)",
borderRadius: "15px",
},
marker: `
border-left: solid 1px orange;
padding: 0 2px 0 5px;
font-size: 0.7rem;
border-radius: 0 3px 3px 0;
position: absolute;
width: 100px;
max-width: fit-content;
cursor: pointer;
background-color: white;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
transition: width 100ms linear;
z-index: 0;
`,
markerHover: { backgroundColor: "orange" },
};

View File

@@ -14,6 +14,7 @@ import { AudioWaveform } from "../api";
import AudioInputsDropdown from "./audioInputsDropdown"; import AudioInputsDropdown from "./audioInputsDropdown";
import { Option } from "react-dropdown"; import { Option } from "react-dropdown";
import { useError } from "../(errors)/errorContext"; import { useError } from "../(errors)/errorContext";
import { waveSurferStyles } from "../styles/recorder";
type RecorderProps = { type RecorderProps = {
setStream?: React.Dispatch<React.SetStateAction<MediaStream | null>>; setStream?: React.Dispatch<React.SetStateAction<MediaStream | null>>;
@@ -94,20 +95,30 @@ export default function Recorder(props: RecorderProps) {
}; };
}; };
// Setup Shortcuts
useEffect(() => {
if (!record) return;
return setupProjectorKeys();
}, [record, deviceId]);
// Waveform setup
useEffect(() => { useEffect(() => {
if (waveformRef.current) { if (waveformRef.current) {
console.log(props.waveform);
const _wavesurfer = WaveSurfer.create({ const _wavesurfer = WaveSurfer.create({
container: waveformRef.current, container: waveformRef.current,
waveColor: "#777", url: props.transcriptId
progressColor: "#222", ? `${process.env.NEXT_PUBLIC_API_URL}/v1/transcripts/${props.transcriptId}/audio/mp3`
cursorColor: "OrangeRed", : undefined,
peaks: props.waveform?.data,
hideScrollbar: true, hideScrollbar: true,
autoCenter: true, autoCenter: true,
barWidth: 2, barWidth: 2,
height: "auto", height: "auto",
url: props.transcriptId
? `${process.env.NEXT_PUBLIC_API_URL}/v1/transcripts/${props.transcriptId}/audio/mp3` ...waveSurferStyles.player,
: undefined,
}); });
if (!props.transcriptId) { if (!props.transcriptId) {
@@ -115,10 +126,12 @@ export default function Recorder(props: RecorderProps) {
_wshack.renderer.renderSingleCanvas = () => {}; _wshack.renderer.renderSingleCanvas = () => {};
} }
// styling
const wsWrapper = _wavesurfer.getWrapper(); const wsWrapper = _wavesurfer.getWrapper();
wsWrapper.style.cursor = "pointer"; wsWrapper.style.cursor = waveSurferStyles.playerStyle.cursor;
wsWrapper.style.backgroundColor = "RGB(240 240 240)"; wsWrapper.style.backgroundColor =
wsWrapper.style.borderRadius = "15px"; waveSurferStyles.playerStyle.backgroundColor;
wsWrapper.style.borderRadius = waveSurferStyles.playerStyle.borderRadius;
_wavesurfer.on("play", () => { _wavesurfer.on("play", () => {
setIsPlaying(true); setIsPlaying(true);
@@ -131,9 +144,10 @@ export default function Recorder(props: RecorderProps) {
setRecord(_wavesurfer.registerPlugin(RecordPlugin.create())); setRecord(_wavesurfer.registerPlugin(RecordPlugin.create()));
setWaveRegions(_wavesurfer.registerPlugin(CustomRegionsPlugin.create())); setWaveRegions(_wavesurfer.registerPlugin(CustomRegionsPlugin.create()));
if (props.transcriptId) _wavesurfer.toggleInteraction(true); if (props.isPastMeeting) _wavesurfer.toggleInteraction(true);
setWavesurfer(_wavesurfer); setWavesurfer(_wavesurfer);
return () => { return () => {
_wavesurfer.destroy(); _wavesurfer.destroy();
setIsRecording(false); setIsRecording(false);
@@ -152,35 +166,18 @@ export default function Recorder(props: RecorderProps) {
if (!waveRegions) return; if (!waveRegions) return;
waveRegions.clearRegions(); waveRegions.clearRegions();
for (let topic of topicsRef.current) { for (let topic of topicsRef.current) {
const content = document.createElement("div"); const content = document.createElement("div");
content.setAttribute( content.setAttribute("style", waveSurferStyles.marker);
"style",
`
position: absolute;
border-left: solid 1px orange;
padding: 0 2px 0 5px;
font-size: 0.7rem;
width: 100px;
max-width: fit-content;
cursor: pointer;
background-color: white;
border-radius: 0 3px 3px 0;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
transition: width 100ms linear;
`,
);
content.onmouseover = () => { content.onmouseover = () => {
content.style.backgroundColor = "orange"; content.style.backgroundColor =
waveSurferStyles.markerHover.backgroundColor;
content.style.zIndex = "999"; content.style.zIndex = "999";
content.style.width = "300px"; content.style.width = "300px";
}; };
content.onmouseout = () => { content.onmouseout = () => {
content.style.backgroundColor = "white"; content.setAttribute("style", waveSurferStyles.marker);
content.style.zIndex = "0";
content.style.width = "100px";
}; };
content.textContent = topic.title; content.textContent = topic.title;
@@ -198,12 +195,6 @@ export default function Recorder(props: RecorderProps) {
} }
}; };
useEffect(() => {
if (!record) return;
return setupProjectorKeys();
}, [record, deviceId]);
useEffect(() => { useEffect(() => {
if (!record) return; if (!record) return;
@@ -214,6 +205,7 @@ export default function Recorder(props: RecorderProps) {
link.setAttribute("href", record.getRecordedUrl()); link.setAttribute("href", record.getRecordedUrl());
link.setAttribute("download", "reflector-recording.webm"); link.setAttribute("download", "reflector-recording.webm");
link.style.visibility = "visible"; link.style.visibility = "visible";
renderMarkers(); renderMarkers();
}); });
}, [record]); }, [record]);