// This content populates the video variant modal, which is spawned from the variants table. import React from 'react'; import { Slider, Switch, Collapse, Typography } from 'antd'; import { FieldUpdaterFunc, VideoVariant, UpdateArgs } from '../../types/config-section'; import TextField from './form-textfield'; import { DEFAULT_VARIANT_STATE } from '../../utils/config-constants'; import InfoTip from '../info-tip'; import CPUUsageSelector from './cpu-usage'; const { Panel } = Collapse; const VIDEO_VARIANT_DEFAULTS = { framerate: { min: 24, max: 120, defaultValue: 24, unit: 'fps', incrementBy: null, tip: 'You prob wont need to touch this unless youre a hardcore gamer and need all the bitties', }, videoBitrate: { min: 600, max: 6000, defaultValue: 1200, unit: 'kbps', incrementBy: 100, tip: 'This is importatnt yo', }, audioBitrate: { min: 600, max: 1200, defaultValue: 800, unit: 'kbps', incrementBy: 100, tip: 'nothing to see here', }, videoPassthrough: { tip: 'If No is selected, then you should set your desired Video Bitrate.', }, audioPassthrough: { tip: 'If No is selected, then you should set your desired Audio Bitrate.', }, scaledWidth: { fieldName: 'scaledWidth', label: 'Resized Width', maxLength: 4, placeholder: '1080', tip: "Optionally resize this content's width.", }, scaledHeight: { fieldName: 'scaledHeight', label: 'Resized Height', maxLength: 4, placeholder: '720', tip: "Optionally resize this content's height.", }, }; interface VideoVariantFormProps { dataState: VideoVariant; onUpdateField: FieldUpdaterFunc; } export default function VideoVariantForm({ dataState = DEFAULT_VARIANT_STATE, onUpdateField, }: VideoVariantFormProps) { const handleFramerateChange = (value: number) => { onUpdateField({ fieldName: 'framerate', value }); }; const handleVideoBitrateChange = (value: number) => { onUpdateField({ fieldName: 'videoBitrate', value }); }; const handleVideoPassChange = (value: boolean) => { onUpdateField({ fieldName: 'videoPassthrough', value }); }; const handleVideoCpuUsageLevelChange = (value: number) => { onUpdateField({ fieldName: 'cpuUsageLevel', value }); }; const handleScaledWidthChanged = (args: UpdateArgs) => { const value = Number(args.value); // eslint-disable-next-line no-restricted-globals if (isNaN(value)) { return; } onUpdateField({ fieldName: 'scaledWidth', value: value || '' }); }; const handleScaledHeightChanged = (args: UpdateArgs) => { const value = Number(args.value); // eslint-disable-next-line no-restricted-globals if (isNaN(value)) { return; } onUpdateField({ fieldName: 'scaledHeight', value: value || '' }); }; const framerateDefaults = VIDEO_VARIANT_DEFAULTS.framerate; const framerateMin = framerateDefaults.min; const framerateMax = framerateDefaults.max; const framerateUnit = framerateDefaults.unit; const framerateMarks = { [framerateMin]: `${framerateMin} ${framerateUnit}`, 30: '', 60: '', [framerateMax]: `${framerateMax} ${framerateUnit}`, }; const videoBitrateDefaults = VIDEO_VARIANT_DEFAULTS.videoBitrate; const videoBRMin = videoBitrateDefaults.min; const videoBRMax = videoBitrateDefaults.max; const videoBRUnit = videoBitrateDefaults.unit; const videoBRMarks = { [videoBRMin]: `${videoBRMin} ${videoBRUnit}`, 3000: 3000, 4500: 4500, [videoBRMax]: `${videoBRMax} ${videoBRUnit}`, }; const selectedVideoBRnote = () => { let note = `Selected: ${dataState.videoBitrate}${videoBRUnit}`; if (dataState.videoBitrate < 3000) { note = `${note} - Good for low bandwidth environments.`; } else if (dataState.videoBitrate < 4500) { note = `${note} - Good for most bandwidth environments.`; } else { note = `${note} - Good for high bandwidth environments.`; } return note; }; const selectedFramerateNote = () => { let note = `Selected: ${dataState.framerate}${framerateUnit}`; switch (dataState.framerate) { case 24: note = `${note} - Good for film, presentations, music, low power/bandwidth servers.`; break; case 30: note = `${note} - Good for slow/casual games, chat, general purpose.`; break; case 60: note = `${note} - Good for fast/action games, sports, HD video.`; break; case 120: note = `${note} - Experimental, use at your own risk!`; break; default: note = ''; } return note; }; const selectedPresetNote = ''; return (

Say a thing here about how this all works. Read more{' '} here.

{/* ENCODER PRESET FIELD */}
{selectedPresetNote && ( {selectedPresetNote} )}
{/* VIDEO PASSTHROUGH FIELD */}

Use Video Passthrough?

{/* todo: change to ToggleSwitch for layout */}
{/* VIDEO BITRATE FIELD */}
Video Bitrate

{VIDEO_VARIANT_DEFAULTS.videoBitrate.tip}

`${value} ${videoBRUnit}`} disabled={dataState.videoPassthrough === true} defaultValue={dataState.videoBitrate} value={dataState.videoBitrate} onChange={handleVideoBitrateChange} step={videoBitrateDefaults.incrementBy} min={videoBRMin} max={videoBRMax} marks={videoBRMarks} /> {selectedVideoBRnote()}
Resizing your content will take additional resources on your server. If you wish to optionally resize your output for this stream variant then you should either set the width or the height to keep your aspect ratio.
{/* FRAME RATE FIELD */}

Frame rate:

`${value} ${framerateUnit}`} defaultValue={dataState.framerate} value={dataState.framerate} onChange={handleFramerateChange} step={framerateDefaults.incrementBy} min={framerateMin} max={framerateMax} marks={framerateMarks} /> {selectedFramerateNote()}
); }