lemmy-ui/src/shared/components/user-details.tsx

214 lines
4.8 KiB
TypeScript
Raw Normal View History

import { Component, linkEvent } from 'inferno';
import { i18n } from '../i18next';
2020-12-24 01:58:27 +00:00
import {
PostView,
CommentView,
SortType,
GetUserDetailsResponse,
UserViewSafe,
} from 'lemmy-js-client';
import { UserDetailsView } from '../interfaces';
2020-09-09 00:48:17 +00:00
import { commentsToFlatNodes, setupTippy } from '../utils';
import { PostListing } from './post-listing';
import { CommentNodes } from './comment-nodes';
interface UserDetailsProps {
2020-12-24 01:58:27 +00:00
userRes: GetUserDetailsResponse;
admins: UserViewSafe[];
page: number;
limit: number;
sort: SortType;
enableDownvotes: boolean;
enableNsfw: boolean;
view: UserDetailsView;
onPageChange(page: number): number | any;
}
2020-09-09 00:48:17 +00:00
interface UserDetailsState {}
2020-12-24 01:58:27 +00:00
enum ItemEnum {
Comment,
Post,
}
type ItemType = {
id: number;
type_: ItemEnum;
view: CommentView | PostView;
published: string;
score: number;
};
export class UserDetails extends Component<UserDetailsProps, UserDetailsState> {
constructor(props: any, context: any) {
super(props, context);
}
2020-09-09 00:48:17 +00:00
// TODO needed here?
componentDidMount() {
setupTippy();
}
2020-09-09 00:48:17 +00:00
// TODO wut?
// componentDidUpdate(lastProps: UserDetailsProps) {
// for (const key of Object.keys(lastProps)) {
// if (lastProps[key] !== this.props[key]) {
// this.fetchUserData();
// break;
// }
// }
// }
render() {
return (
<div>
{this.viewSelector(this.props.view)}
{this.paginator()}
</div>
);
}
viewSelector(view: UserDetailsView) {
if (view === UserDetailsView.Overview || view === UserDetailsView.Saved) {
return this.overview();
2020-09-09 00:48:17 +00:00
} else if (view === UserDetailsView.Comments) {
return this.comments();
2020-09-09 00:48:17 +00:00
} else if (view === UserDetailsView.Posts) {
return this.posts();
2020-09-09 00:48:17 +00:00
} else {
return null;
}
}
2020-12-24 01:58:27 +00:00
renderItemType(i: ItemType) {
switch (i.type_) {
case ItemEnum.Comment:
let c = i.view as CommentView;
return (
<CommentNodes
key={i.id}
nodes={[{ comment_view: c }]}
admins={this.props.admins}
noBorder
noIndent
showCommunity
showContext
enableDownvotes={this.props.enableDownvotes}
/>
);
case ItemEnum.Post:
let p = i.view as PostView;
return (
<PostListing
key={i.id}
post_view={p}
admins={this.props.admins}
showCommunity
enableDownvotes={this.props.enableDownvotes}
enableNsfw={this.props.enableNsfw}
/>
);
default:
return <div />;
}
}
overview() {
2020-12-24 01:58:27 +00:00
let id = 0;
let comments: ItemType[] = this.props.userRes.comments.map(r => ({
id: id++,
type_: ItemEnum.Comment,
view: r,
published: r.comment.published,
score: r.counts.score,
}));
let posts: ItemType[] = this.props.userRes.posts.map(r => ({
id: id++,
type_: ItemEnum.Comment,
view: r,
published: r.post.published,
score: r.counts.score,
}));
let combined = [...comments, ...posts];
// Sort it
if (this.props.sort === SortType.New) {
2020-12-24 01:58:27 +00:00
combined.sort((a, b) => b.published.localeCompare(a.published));
} else {
2020-12-24 01:58:27 +00:00
combined.sort((a, b) => b.score - a.score);
}
return (
<div>
2020-12-24 01:58:27 +00:00
{combined.map(i => [this.renderItemType(i), <hr class="my-3" />])}
</div>
);
}
comments() {
return (
<div>
<CommentNodes
2020-09-09 00:48:17 +00:00
nodes={commentsToFlatNodes(this.props.userRes.comments)}
2020-12-24 01:58:27 +00:00
admins={this.props.admins}
noIndent
showCommunity
showContext
enableDownvotes={this.props.enableDownvotes}
/>
</div>
);
}
posts() {
return (
<div>
2020-09-09 00:48:17 +00:00
{this.props.userRes.posts.map(post => (
<>
<PostListing
2020-12-24 01:58:27 +00:00
post_view={post}
admins={this.props.admins}
showCommunity
enableDownvotes={this.props.enableDownvotes}
enableNsfw={this.props.enableNsfw}
/>
<hr class="my-3" />
</>
))}
</div>
);
}
paginator() {
return (
<div class="my-2">
{this.props.page > 1 && (
<button
class="btn btn-secondary mr-1"
onClick={linkEvent(this, this.prevPage)}
>
{i18n.t('prev')}
</button>
)}
2020-09-09 00:48:17 +00:00
{this.props.userRes.comments.length + this.props.userRes.posts.length >
0 && (
<button
class="btn btn-secondary"
onClick={linkEvent(this, this.nextPage)}
>
{i18n.t('next')}
</button>
)}
</div>
);
}
nextPage(i: UserDetails) {
i.props.onPageChange(i.props.page + 1);
}
prevPage(i: UserDetails) {
i.props.onPageChange(i.props.page - 1);
}
}