2020-08-31 21:19:46 +03:00
|
|
|
import * as React from "react";
|
|
|
|
import * as Actions from "~/common/actions";
|
2020-12-20 05:19:32 +03:00
|
|
|
import * as SVG from "~/common/svg";
|
2020-08-31 21:19:46 +03:00
|
|
|
|
2020-11-30 08:24:22 +03:00
|
|
|
import { css } from "@emotion/react";
|
2020-10-31 02:12:20 +03:00
|
|
|
import { ButtonPrimary, ButtonSecondary } from "~/components/system/components/Buttons";
|
2020-12-20 05:19:32 +03:00
|
|
|
import { LoaderSpinner } from "~/components/system/components/Loaders";
|
2020-08-31 21:19:46 +03:00
|
|
|
|
|
|
|
import ScenePage from "~/components/core/ScenePage";
|
|
|
|
import Profile from "~/components/core/Profile";
|
2020-12-20 05:19:32 +03:00
|
|
|
import EmptyState from "~/components/core/EmptyState";
|
2020-08-31 21:19:46 +03:00
|
|
|
|
2020-09-15 00:29:41 +03:00
|
|
|
const STYLES_BUTTONS = css`
|
|
|
|
display: inline-flex;
|
|
|
|
flex-direction: row;
|
|
|
|
align-items: center;
|
|
|
|
`;
|
|
|
|
|
2020-12-20 05:19:32 +03:00
|
|
|
const STYLES_LOADER = css`
|
|
|
|
display: flex;
|
|
|
|
align-items: center;
|
|
|
|
justify-content: center;
|
|
|
|
height: 90vh;
|
|
|
|
width: 100%;
|
|
|
|
`;
|
|
|
|
|
2020-08-31 21:19:46 +03:00
|
|
|
export default class SceneProfile extends React.Component {
|
2020-12-20 05:19:32 +03:00
|
|
|
state = {
|
|
|
|
profile: null,
|
|
|
|
notFound: false,
|
|
|
|
};
|
|
|
|
|
|
|
|
componentDidMount = async () => {
|
|
|
|
await this.fetchProfile();
|
|
|
|
};
|
|
|
|
|
|
|
|
componentDidUpdate = async (prevProps) => {
|
|
|
|
if (
|
|
|
|
this.props.data &&
|
|
|
|
prevProps.data &&
|
|
|
|
this.props.data.id &&
|
|
|
|
prevProps.data.id &&
|
|
|
|
this.props.data.id !== prevProps.data.id
|
|
|
|
) {
|
|
|
|
await this.fetchProfile();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
fetchProfile = async () => {
|
|
|
|
const { user: username } = window.history.state;
|
|
|
|
let query;
|
|
|
|
let targetUser;
|
|
|
|
if (username) {
|
|
|
|
if (username === this.props.viewer.username) {
|
|
|
|
targetUser = this.props.viewer;
|
|
|
|
} else {
|
|
|
|
query = { username: username };
|
|
|
|
}
|
|
|
|
} else if (this.props.data && this.props.data.id) {
|
|
|
|
if (this.props.data.id === this.props.viewer.id) {
|
|
|
|
targetUser = this.props.viewer;
|
|
|
|
} else {
|
|
|
|
query = { id: this.props.data.id };
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!targetUser) {
|
|
|
|
let response;
|
|
|
|
if (query) {
|
|
|
|
response = await Actions.getSerializedProfile(query);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!response || response.error) {
|
|
|
|
this.setState({ notFound: true });
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
targetUser = response.data;
|
|
|
|
}
|
2021-01-09 07:13:00 +03:00
|
|
|
console.log(targetUser);
|
2020-12-20 05:19:32 +03:00
|
|
|
|
|
|
|
window.history.replaceState(window.history.state, "A slate user", `/${targetUser.username}`);
|
|
|
|
|
|
|
|
this.props.onUpdateData({ data: targetUser });
|
|
|
|
this.setState({ profile: targetUser });
|
|
|
|
};
|
|
|
|
|
|
|
|
render() {
|
|
|
|
if (this.state.notFound) {
|
|
|
|
return (
|
|
|
|
<ScenePage>
|
|
|
|
<EmptyState>
|
|
|
|
<SVG.Users height="24px" style={{ marginBottom: 24 }} />
|
|
|
|
<div>We were unable to locate that user profile</div>
|
|
|
|
</EmptyState>
|
|
|
|
</ScenePage>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!this.state.profile) {
|
|
|
|
return (
|
|
|
|
<div css={STYLES_LOADER}>
|
|
|
|
<LoaderSpinner />
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return <ProfilePage {...this.props} data={this.state.profile} />;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class ProfilePage extends React.Component {
|
2020-12-15 04:43:16 +03:00
|
|
|
state = {
|
|
|
|
isFollowing: !!this.props.viewer.subscriptions.filter((entry) => {
|
|
|
|
return entry.target_user_id === this.props.data.id;
|
|
|
|
}).length,
|
|
|
|
};
|
|
|
|
|
|
|
|
componentDidUpdate = (prevProps) => {
|
|
|
|
if (
|
|
|
|
this.props.data.id !== prevProps.data.id ||
|
|
|
|
this.props.viewer.subscriptions !== prevProps.viewer.subscriptions
|
|
|
|
) {
|
|
|
|
this.setState({
|
|
|
|
isFollowing: !!this.props.viewer.subscriptions.filter((entry) => {
|
|
|
|
return entry.target_user_id === this.props.data.id;
|
|
|
|
}).length,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2020-10-31 02:12:20 +03:00
|
|
|
_handleFollow = async () => {
|
2020-12-15 04:43:16 +03:00
|
|
|
this.setState({ isFollowing: !this.state.isFollowing });
|
2020-10-31 02:12:20 +03:00
|
|
|
await Actions.createSubscription({
|
|
|
|
userId: this.props.data.id,
|
|
|
|
});
|
2020-08-31 21:19:46 +03:00
|
|
|
};
|
|
|
|
|
2020-10-31 02:12:20 +03:00
|
|
|
render() {
|
2020-08-31 21:19:46 +03:00
|
|
|
let buttons = (
|
2020-09-15 00:29:41 +03:00
|
|
|
<div css={STYLES_BUTTONS}>
|
2020-12-15 04:43:16 +03:00
|
|
|
{this.state.isFollowing ? (
|
2020-12-13 04:16:55 +03:00
|
|
|
<ButtonSecondary style={{ marginRight: 8 }} onClick={this._handleFollow}>
|
2020-09-03 00:08:32 +03:00
|
|
|
Unfollow
|
|
|
|
</ButtonSecondary>
|
|
|
|
) : (
|
2020-12-13 04:16:55 +03:00
|
|
|
<ButtonPrimary style={{ marginRight: 8 }} onClick={this._handleFollow}>
|
2020-09-03 00:08:32 +03:00
|
|
|
Follow
|
|
|
|
</ButtonPrimary>
|
|
|
|
)}
|
2020-08-31 21:19:46 +03:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
return (
|
2020-09-03 00:08:32 +03:00
|
|
|
<ScenePage>
|
2020-08-31 21:19:46 +03:00
|
|
|
<Profile
|
2020-09-03 02:17:31 +03:00
|
|
|
{...this.props}
|
2020-08-31 21:19:46 +03:00
|
|
|
onAction={this.props.onAction}
|
|
|
|
creator={this.props.data}
|
|
|
|
sceneId={this.props.sceneId}
|
2020-10-31 02:12:20 +03:00
|
|
|
buttons={this.props.viewer.username === this.props.data.username ? null : buttons}
|
2020-10-05 00:30:28 +03:00
|
|
|
isOwner={this.props.viewer.username === this.props.data.username}
|
2020-08-31 21:19:46 +03:00
|
|
|
/>
|
|
|
|
</ScenePage>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|