import { h, Component } from '/js/web_modules/preact.js'; import htm from '/js/web_modules/htm.js'; import { ExternalActionButton } from './external-action-modal.js'; const html = htm.bind(h); function validateAccount(account) { account = account.replace(/^@+/, ''); var regex = /^(([^<>()[\]\\.,;:\s@\"]+(\.[^<>()[\]\\.,;:\s@\"]+)*)|(\".+\"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/; return regex.test(String(account).toLowerCase()); } export default class FediverseFollowModal extends Component { constructor(props) { super(props); this.remoteFollowButtonPressed = this.remoteFollowButtonPressed.bind(this); this.state = { errorMessage: null, value: '', loading: false, valid: false, }; } async remoteFollowButtonPressed() { if (!this.state.valid) { return; } this.setState({ loading: true, errorMessage: null }); const { value } = this.state; const { onClose } = this.props; const account = value.replace(/^@+/, ''); const request = { account: account }; const requestURL = '/api/remotefollow'; const rawResponse = await fetch(requestURL, { method: 'POST', body: JSON.stringify(request), }); const result = await rawResponse.json(); if (!result.redirectUrl) { this.setState({ errorMessage: result.message, loading: false }); return; } window.open(result.redirectUrl, '_blank'); onClose(); } navigateToFediverseJoinPage() { window.open('https://owncast.online/join-fediverse', '_blank'); } onInput = (e) => { const { value } = e.target; const valid = validateAccount(value); this.setState({ value, valid }); }; render() { const { name, federationInfo = {}, logo } = this.props; const { account } = federationInfo; const { errorMessage, value, valid, loading } = this.state; const buttonState = valid ? '' : 'cursor-not-allowed opacity-50'; const error = errorMessage ? html` ` : null; const loaderStyle = loading ? 'flex' : 'none'; return html`

By following this stream you'll get posts and notifications such as when it goes live.

${name}
${account}

${error}

You'll be redirected to your Fediverse server and asked to confirm this action. ${' '} Join the Fediverse if you haven't.

Contacting your server.

Please wait...

`; } } export function FediverseFollowButton({ serverName, federationInfo, onClick }) { const fediverseFollowAction = { color: 'rgba(28, 26, 59, 1)', description: `Follow ${serverName} at ${federationInfo.account}`, icon: '/img/fediverse-color.png', openExternally: false, title: `Follow ${serverName}`, url: '', }; const handleClick = () => onClick(fediverseFollowAction); return html` <${ExternalActionButton} onClick=${handleClick} action=${fediverseFollowAction} label=${`Follow ${ federationInfo.followerCount > 10 ? ` (${federationInfo.followerCount})` : '' }`} /> `; }