1 import axios from 'axios';
2 import React, { useEffect, useState } from 'react';
3 import { useParams } from 'react-router-dom';
5 import ErrorBoundary from '../common/ErrorBoundary';
6 import ErrorMessage from '../common/ErrorMessage';
7 import Loading from '../common/Loading';
8 import NotFound from '../pages/NotFound';
9 import Profile from '../users/Profile';
12 const params = useParams();
13 const { id } = params;
15 const [error, setError] = useState(null);
16 const [loading, setLoading] = useState(true);
17 const [user, setUser] = useState(null);
22 .get(`/api/users/${id}`)
26 setUser(response.data);
27 window.document.title = response.data.nickname || response.data.username;
39 setUser(user => e.user.id === user.id ? { ...user, ...e.user } : user);
42 window.Echo.channel('App.Control')
43 .listen('UserChanged', cb);
45 window.Echo.channel('App.Control')
46 .stopListening('UserChanged', cb);
55 return <ErrorMessage error={error} />;
62 return <ErrorBoundary>
63 <Profile user={user} />