mirror of
https://github.com/owncast/owncast.git
synced 2025-01-02 22:57:39 +03:00
d0eb1446f3
* up max char count for variant name to fix https://github.com/owncast/owncast/issues/1037 * max widthing the line chart canvas size so it scales with the page. fixes - https://github.com/owncast/owncast/issues/842 - https://github.com/owncast/owncast/issues/1024 * A fix to make Storage Endpoint URL validation have better feedback. - give the field a type of "url" - give the field a pattern to check - have native browser handle the validation - if the field is invalid, use :invalid selector to turn the text red on blur. fixes: https://github.com/owncast/owncast/issues/1000 * a fix for https://github.com/owncast/owncast/issues/874 * - fixes for https://github.com/owncast/owncast/issues/972 Add optional prop to text field to trim() whitespaces from field. Apply logic to mostly url fields. - move textfield blur if invalid turn red to globaal * - a fix for bug: https://github.com/owncast/owncast/issues/998 don't return null if platform name not found because its custom. - clean up react key problem on socialhandles table * fix react key issue on Actions table * fix for https://github.com/owncast/owncast/issues/1008 to display 'other' field when editing an item not in predefined social list * clean up other potential react key warnings * Prettified Code! Co-authored-by: gingervitis <gingervitis@users.noreply.github.com>
163 lines
5.4 KiB
TypeScript
163 lines
5.4 KiB
TypeScript
import React, { useContext, useState, useEffect } from 'react';
|
|
import { Typography, Select, Popconfirm } from 'antd';
|
|
import { ServerStatusContext } from '../../utils/server-status-context';
|
|
import { AlertMessageContext } from '../../utils/alert-message-context';
|
|
import {
|
|
API_VIDEO_CODEC,
|
|
RESET_TIMEOUT,
|
|
postConfigUpdateToAPI,
|
|
} from '../../utils/config-constants';
|
|
import {
|
|
createInputStatus,
|
|
StatusState,
|
|
STATUS_ERROR,
|
|
STATUS_PROCESSING,
|
|
STATUS_SUCCESS,
|
|
} from '../../utils/input-statuses';
|
|
import FormStatusIndicator from './form-status-indicator';
|
|
|
|
export default function CodecSelector() {
|
|
const serverStatusData = useContext(ServerStatusContext);
|
|
const { serverConfig, setFieldInConfigState } = serverStatusData || {};
|
|
const { videoCodec, supportedCodecs } = serverConfig || {};
|
|
const { Title } = Typography;
|
|
const { Option } = Select;
|
|
const [submitStatus, setSubmitStatus] = useState<StatusState>(null);
|
|
const { setMessage } = useContext(AlertMessageContext);
|
|
const [selectedCodec, setSelectedCodec] = useState(videoCodec);
|
|
const [pendingSaveCodec, setPendingSavecodec] = useState(videoCodec);
|
|
const [confirmPopupVisible, setConfirmPopupVisible] = React.useState(false);
|
|
|
|
let resetTimer = null;
|
|
|
|
useEffect(() => {
|
|
setSelectedCodec(videoCodec);
|
|
}, [videoCodec]);
|
|
|
|
const resetStates = () => {
|
|
setSubmitStatus(null);
|
|
resetTimer = null;
|
|
clearTimeout(resetTimer);
|
|
};
|
|
|
|
function handleChange(value) {
|
|
setPendingSavecodec(value);
|
|
setConfirmPopupVisible(true);
|
|
}
|
|
|
|
async function save() {
|
|
setSelectedCodec(pendingSaveCodec);
|
|
setPendingSavecodec('');
|
|
setConfirmPopupVisible(false);
|
|
|
|
await postConfigUpdateToAPI({
|
|
apiPath: API_VIDEO_CODEC,
|
|
data: { value: pendingSaveCodec },
|
|
onSuccess: () => {
|
|
setFieldInConfigState({
|
|
fieldName: 'videoCodec',
|
|
value: pendingSaveCodec,
|
|
path: 'videoSettings',
|
|
});
|
|
setSubmitStatus(createInputStatus(STATUS_SUCCESS, 'Video codec updated.'));
|
|
|
|
resetTimer = setTimeout(resetStates, RESET_TIMEOUT);
|
|
if (serverStatusData.online) {
|
|
setMessage(
|
|
'Your latency buffer setting will take effect the next time you begin a live stream.',
|
|
);
|
|
}
|
|
},
|
|
onError: (message: string) => {
|
|
setSubmitStatus(createInputStatus(STATUS_ERROR, message));
|
|
|
|
resetTimer = setTimeout(resetStates, RESET_TIMEOUT);
|
|
},
|
|
});
|
|
}
|
|
|
|
const items = supportedCodecs.map(function (codec) {
|
|
var title = codec;
|
|
if (title === 'libx264') {
|
|
title = 'Default (libx264)';
|
|
} else if (title === 'h264_nvenc') {
|
|
title = 'NVIDIA GPU acceleration';
|
|
} else if (title === 'h264_vaapi') {
|
|
title = 'VA-API hardware encoding';
|
|
} else if (title === 'h264_qsv') {
|
|
title = 'Intel QuickSync';
|
|
} else if (title === 'h264_v4l2m2m') {
|
|
title = 'Video4Linux hardware encoding';
|
|
}
|
|
|
|
return (
|
|
<Option key={codec} value={codec}>
|
|
{title}
|
|
</Option>
|
|
);
|
|
});
|
|
|
|
var description = '';
|
|
if (selectedCodec === 'libx264') {
|
|
description =
|
|
'libx264 is the default codec and generally the only working choice for shared VPS enviornments. This is likely what you should be using unless you know you have set up other options.';
|
|
} else if (selectedCodec === 'h264_nvenc') {
|
|
description =
|
|
'You can use your NVIDIA GPU for encoding if you have a modern NVIDIA card with encoding cores.';
|
|
} else if (selectedCodec === 'h264_vaapi') {
|
|
description =
|
|
'VA-API may be supported by your NVIDIA proprietary drivers, Mesa open-source drivers for AMD or Intel graphics.';
|
|
} else if (selectedCodec === 'h264_qsv') {
|
|
description =
|
|
"Quick Sync Video is Intel's brand for its dedicated video encoding and decoding hardware. It may be an option if you have a modern Intel CPU with integrated graphics.";
|
|
} else if (selectedCodec === 'h264_v4l2m2m') {
|
|
description =
|
|
'Video4Linux is an interface to multiple different hardware encoding platforms such as Intel and AMD.';
|
|
}
|
|
|
|
return (
|
|
<>
|
|
<Title level={3} className="section-title">
|
|
Video Codec
|
|
</Title>
|
|
<div className="description">
|
|
If you have access to specific hardware with the drivers and software installed for them,
|
|
you may be able to improve your video encoding performance.
|
|
<p>
|
|
<a
|
|
href="https://owncast.online/docs/codecs?source=admin"
|
|
target="_blank"
|
|
rel="noopener noreferrer"
|
|
>
|
|
Read the documentation about this setting before changing it or you may make your stream
|
|
unplayable.
|
|
</a>
|
|
</p>
|
|
</div>
|
|
<div className="segment-slider-container">
|
|
<Popconfirm
|
|
title={`Are you sure you want to change your video codec to ${pendingSaveCodec} and understand what this means?`}
|
|
visible={confirmPopupVisible}
|
|
placement={'leftBottom'}
|
|
onConfirm={save}
|
|
okText={'Yes'}
|
|
cancelText={'No'}
|
|
>
|
|
<Select
|
|
defaultValue={selectedCodec}
|
|
value={selectedCodec}
|
|
style={{ width: '100%' }}
|
|
onChange={handleChange}
|
|
>
|
|
{items}
|
|
</Select>
|
|
</Popconfirm>
|
|
<FormStatusIndicator status={submitStatus} />
|
|
|
|
<p id="selected-codec-note" className="selected-value-note">
|
|
{description}
|
|
</p>
|
|
</div>
|
|
</>
|
|
);
|
|
}
|