1 import { Component } from 'inferno';
2 import { Subscription } from 'rxjs';
3 import { PrivateMessageForm } from './private-message-form';
4 import { HtmlTags } from './html-tags';
5 import { UserService, WebSocketService } from '../services';
14 } from 'lemmy-js-client';
16 getRecipientIdFromProps,
24 import { i18n } from '../i18next';
25 import { InitialFetchRequest } from 'shared/interfaces';
27 interface CreatePrivateMessageProps {}
29 interface CreatePrivateMessageState {
36 export class CreatePrivateMessage extends Component<
37 CreatePrivateMessageProps,
38 CreatePrivateMessageState
40 private isoData = setIsoData(this.context);
41 private subscription: Subscription;
42 private emptyState: CreatePrivateMessageState = {
43 site: this.isoData.site.site,
45 recipient_id: getRecipientIdFromProps(this.props),
48 constructor(props: any, context: any) {
49 super(props, context);
50 this.state = this.emptyState;
51 this.handlePrivateMessageCreate = this.handlePrivateMessageCreate.bind(
55 this.parseMessage = this.parseMessage.bind(this);
56 this.subscription = wsSubscribe(this.parseMessage);
58 if (!UserService.Instance.user) {
59 toast(i18n.t('not_logged_in'), 'danger');
60 this.context.router.history.push(`/login`);
63 // Only fetch the data if coming from another route
64 if (this.isoData.path == this.context.router.route.match.url) {
65 this.state.recipient = this.isoData.routeData[0].user;
66 this.state.loading = false;
68 this.fetchUserDetails();
73 let form: GetUserDetailsForm = {
74 user_id: this.state.recipient_id,
78 WebSocketService.Instance.getUserDetails(form);
81 static fetchInitialData(req: InitialFetchRequest): Promise<any>[] {
82 let user_id = Number(req.path.split('/').pop());
83 let form: GetUserDetailsForm = {
88 setAuth(form, req.auth);
89 return [req.client.getUserDetails(form)];
92 get documentTitle(): string {
93 return `${i18n.t('create_private_message')} - ${this.state.site.name}`;
96 componentWillUnmount() {
98 this.subscription.unsubscribe();
104 <div class="container">
106 title={this.documentTitle}
107 path={this.context.router.route.match.url}
109 {this.state.loading ? (
111 <svg class="icon icon-spinner spin">
112 <use xlinkHref="#icon-spinner"></use>
117 <div class="col-12 col-lg-6 offset-lg-3 mb-4">
118 <h5>{i18n.t('create_private_message')}</h5>
120 onCreate={this.handlePrivateMessageCreate}
121 recipient={this.state.recipient}
130 handlePrivateMessageCreate() {
131 toast(i18n.t('message_sent'));
133 // Navigate to the front
134 this.context.router.history.push(`/`);
137 parseMessage(msg: WebSocketJsonResponse) {
138 let res = wsJsonToRes(msg);
140 toast(i18n.t(msg.error), 'danger');
141 this.state.loading = false;
142 this.setState(this.state);
144 } else if (res.op == UserOperation.GetUserDetails) {
145 let data = res.data as UserDetailsResponse;
146 this.state.recipient = data.user;
147 this.state.loading = false;
148 this.setState(this.state);