mirror of
https://github.com/owncast/owncast.git
synced 2024-11-23 05:14:20 +03:00
084a01fb02
* ActivityPub admin pages for configuration * Fix dev build * Add support for requiring follow approval. Closes https://github.com/owncast/owncast/issues/1208 * Point at admin version of followers endpoint * Add setting for toggling displaying fediverse engagement in admin. https://github.com/owncast/owncast/issues/1404 * Add instance URL textfield to federation config and disable federation if it is empty * If instance URL is not https disable federation * Tweak federation toggle text. Make go live message optional * Add federation info modal. Closes https://github.com/owncast/owncast/issues/1544 * Add support for blocked federated domains. For https://github.com/owncast/owncast/issues/1209 * Simplify fediverse post input * Add placeholder Fediverse icon * Tweak federation logo in admin menu. Closes https://github.com/owncast/owncast/issues/1603 * Add global button for composing a fediverse post. Closes https://github.com/owncast/owncast/issues/1610 * Federation -> Social * Add page for listing federated actions. Closes https://github.com/owncast/owncast/issues/1573 * Auto-close social post modal after success * Make user modal action buttons look nicer * Center and reduce width and center count column. Closes https://github.com/owncast/owncast/issues/1580 * Update the followers table to be clearer * Fix exception thrown when passing undefined * Disable federation settings if feature is disabled * Update enable social modal. For https://github.com/owncast/owncast/issues/1594 * Fix type props * Quiet, linter * Move compose button to the left * Add tooltip for compose button * Add NSFW toggle to federation config. Closes https://github.com/owncast/owncast/issues/1628 * Add support for blocking/removing followers. For https://github.com/owncast/owncast/issues/1630 * Allow editing the server url field even when federation is disabled * Continue to update the copy around the social features * Use relative path to action images. Fixes https://github.com/owncast/owncast/issues/1646 * Link IRIs and make action verbse present tense * Update caniuse
76 lines
2 KiB
TypeScript
76 lines
2 KiB
TypeScript
import React, { useState } from 'react';
|
|
|
|
import { Button, Space, Input, Modal } from 'antd';
|
|
import { STATUS_ERROR, STATUS_SUCCESS } from '../utils/input-statuses';
|
|
import { fetchData, FEDERATION_MESSAGE_SEND } from '../utils/apis';
|
|
|
|
const { TextArea } = Input;
|
|
|
|
interface ComposeFederatedPostProps {
|
|
visible: boolean;
|
|
handleClose: () => void;
|
|
}
|
|
|
|
export default function ComposeFederatedPost({ visible, handleClose }: ComposeFederatedPostProps) {
|
|
const [content, setContent] = useState('');
|
|
const [postPending, setPostPending] = useState(false);
|
|
const [postSuccessState, setPostSuccessState] = useState(null);
|
|
|
|
function handleEditorChange(e) {
|
|
setContent(e.target.value);
|
|
}
|
|
|
|
async function sendButtonClicked() {
|
|
setPostPending(true);
|
|
|
|
const data = {
|
|
value: content,
|
|
};
|
|
try {
|
|
await fetchData(FEDERATION_MESSAGE_SEND, {
|
|
data,
|
|
method: 'POST',
|
|
auth: true,
|
|
});
|
|
setPostSuccessState(STATUS_SUCCESS);
|
|
setTimeout(handleClose, 1000);
|
|
} catch (e) {
|
|
// eslint-disable-next-line no-console
|
|
console.error(e);
|
|
setPostSuccessState(STATUS_ERROR);
|
|
}
|
|
setPostPending(false);
|
|
}
|
|
|
|
return (
|
|
<Modal
|
|
destroyOnClose
|
|
width={600}
|
|
title="Post to Followers"
|
|
visible={visible}
|
|
onCancel={handleClose}
|
|
footer={[
|
|
<Button onClick={() => handleClose()}>Cancel</Button>,
|
|
<Button
|
|
type="primary"
|
|
onClick={sendButtonClicked}
|
|
disabled={postPending || postSuccessState}
|
|
loading={postPending}
|
|
>
|
|
{postSuccessState?.toUpperCase() || 'Post'}
|
|
</Button>,
|
|
]}
|
|
>
|
|
<Space id="fediverse-post-container" direction="vertical">
|
|
<TextArea
|
|
placeholder="Tell the world about your streaming plans..."
|
|
size="large"
|
|
showCount
|
|
maxLength={500}
|
|
style={{ height: '150px' }}
|
|
onChange={handleEditorChange}
|
|
/>
|
|
</Space>
|
|
</Modal>
|
|
);
|
|
}
|