import React, { useState } from 'react'; import PlexOAuth from '../../utils/plex'; import { defineMessages, useIntl } from 'react-intl'; const messages = defineMessages({ loginwithplex: 'Login with Plex', loading: 'Loading...', loggingin: 'Logging in...', }); const plexOAuth = new PlexOAuth(); interface PlexLoginButtonProps { onAuthToken: (authToken: string) => void; onError?: (message: string) => void; } const PlexLoginButton: React.FC = ({ onAuthToken, onError, }) => { const intl = useIntl(); const [loading, setLoading] = useState(false); const [isProcessing, setIsProcessing] = useState(false); const getPlexLogin = async () => { setLoading(true); try { const authToken = await plexOAuth.login(); setLoading(false); setIsProcessing(true); onAuthToken(authToken); } catch (e) { if (onError) { onError(e.message); } setLoading(false); } }; return ( ); }; export default PlexLoginButton;