import { Component, linkEvent } from 'inferno'; import { PrivateMessage as PrivateMessageI, DeletePrivateMessageForm, MarkPrivateMessageAsReadForm, UserView, } from 'lemmy-js-client'; import { WebSocketService, UserService } from '../services'; import { mdToHtml, toast } from '../utils'; import { MomentTime } from './moment-time'; import { PrivateMessageForm } from './private-message-form'; import { UserListing } from './user-listing'; import { i18n } from '../i18next'; interface PrivateMessageState { showReply: boolean; showEdit: boolean; collapsed: boolean; viewSource: boolean; } interface PrivateMessageProps { privateMessage: PrivateMessageI; } export class PrivateMessage extends Component< PrivateMessageProps, PrivateMessageState > { private emptyState: PrivateMessageState = { showReply: false, showEdit: false, collapsed: false, viewSource: false, }; constructor(props: any, context: any) { super(props, context); this.state = this.emptyState; this.handleReplyCancel = this.handleReplyCancel.bind(this); this.handlePrivateMessageCreate = this.handlePrivateMessageCreate.bind( this ); this.handlePrivateMessageEdit = this.handlePrivateMessageEdit.bind(this); } get mine(): boolean { return ( UserService.Instance.user && UserService.Instance.user.id == this.props.privateMessage.creator_id ); } render() { let message = this.props.privateMessage; let userOther: UserView = this.mine ? { name: message.recipient_name, preferred_username: message.recipient_preferred_username, id: message.recipient_id, avatar: message.recipient_avatar, local: message.recipient_local, actor_id: message.recipient_actor_id, published: message.published, number_of_posts: 0, post_score: 0, number_of_comments: 0, comment_score: 0, banned: false, } : { name: message.creator_name, preferred_username: message.creator_preferred_username, id: message.creator_id, avatar: message.creator_avatar, local: message.creator_local, actor_id: message.creator_actor_id, published: message.published, number_of_posts: 0, post_score: 0, number_of_comments: 0, comment_score: 0, banned: false, }; return (
{this.state.showEdit && ( )} {!this.state.showEdit && !this.state.collapsed && (
{this.state.viewSource ? (
{this.messageUnlessRemoved}
) : (
)}
    {!this.mine && ( <>
  • )} {this.mine && ( <>
  • )}
)}
{this.state.showReply && ( )} {/* A collapsed clearfix */} {this.state.collapsed &&
}
); } get messageUnlessRemoved(): string { let message = this.props.privateMessage; return message.deleted ? `*${i18n.t('deleted')}*` : message.content; } handleReplyClick(i: PrivateMessage) { i.state.showReply = true; i.setState(i.state); } handleEditClick(i: PrivateMessage) { i.state.showEdit = true; i.setState(i.state); } handleDeleteClick(i: PrivateMessage) { let form: DeletePrivateMessageForm = { edit_id: i.props.privateMessage.id, deleted: !i.props.privateMessage.deleted, }; WebSocketService.Instance.deletePrivateMessage(form); } handleReplyCancel() { this.state.showReply = false; this.state.showEdit = false; this.setState(this.state); } handleMarkRead(i: PrivateMessage) { let form: MarkPrivateMessageAsReadForm = { edit_id: i.props.privateMessage.id, read: !i.props.privateMessage.read, }; WebSocketService.Instance.markPrivateMessageAsRead(form); } handleMessageCollapse(i: PrivateMessage) { i.state.collapsed = !i.state.collapsed; i.setState(i.state); } handleViewSource(i: PrivateMessage) { i.state.viewSource = !i.state.viewSource; i.setState(i.state); } handlePrivateMessageEdit() { this.state.showEdit = false; this.setState(this.state); } handlePrivateMessageCreate(message: PrivateMessageI) { if ( UserService.Instance.user && message.creator_id == UserService.Instance.user.id ) { this.state.showReply = false; this.setState(this.state); toast(i18n.t('message_sent')); } } }