/* eslint-disable react/prop-types */ import React, { useState, useEffect } from 'react'; import { Table, Typography, Input } from 'antd'; import { SERVER_CONFIG, fetchData, FETCH_INTERVAL } from '../utils/apis'; import { isEmptyObject } from '../utils/format'; import KeyValueTable from "./components/key-value-table"; const { Title } = Typography; const { TextArea } = Input; export const INITIAL_SERVER_CONFIG_STATE = { streamKey: '', yp: { enabled: false, }, videoSettings: { videoQualityVariants: [ { audioPassthrough: false, videoBitrate: 0, audioBitrate: 0, framerate: 0, }, ], } }; function SocialHandles({ config }) { if (!config) { return null; } const columns = [ { title: "Platform", dataIndex: "platform", key: "platform", }, { title: "URL", dataIndex: "url", key: "url", render: (url) => {url} }, ]; if (!config.instanceDetails?.socialHandles) { return null; } return (
Social Handles ); } function InstanceDetails({ config }) { if (!config || isEmptyObject(config)) { return null; } const { instanceDetails = {}, yp, streamKey, ffmpegPath, webServerPort } = config; const data = [ { name: "Server name", value: instanceDetails.name, }, { name: "Title", value: instanceDetails.title, }, { name: "Summary", value: instanceDetails.summary, }, { name: "Logo", value: instanceDetails.logo?.large, }, { name: "Tags", value: instanceDetails.tags?.join(", "), }, { name: "NSFW", value: instanceDetails.nsfw?.toString(), }, { name: "Shows in Owncast directory", value: yp.enabled.toString(), }, ]; const configData = [ { name: "Stream key", value: streamKey, }, { name: "ffmpeg path", value: ffmpegPath, }, { name: "Web server port", value: webServerPort, }, ]; return ( <> ); } function PageContent({ config }) { if (!config?.instanceDetails?.extraPageContent) { return null; } return (
Page content