1 import { Component, linkEvent } from "inferno";
2 import { T } from "inferno-i18next-dess";
4 PrivateMessageReportView,
5 ResolvePrivateMessageReport,
6 } from "lemmy-js-client";
7 import { i18n } from "../../i18next";
8 import { WebSocketService } from "../../services";
9 import { auth, mdToHtml, wsClient } from "../../utils";
10 import { Icon } from "../common/icon";
11 import { PersonListing } from "../person/person-listing";
14 report: PrivateMessageReportView;
17 export class PrivateMessageReport extends Component<Props, any> {
18 constructor(props: any, context: any) {
19 super(props, context);
23 let r = this.props.report;
24 let pmr = r.private_message_report;
25 let tippyContent = i18n.t(
26 r.private_message_report.resolved ? "unresolve_report" : "resolve_report"
32 {i18n.t("creator")}:{" "}
33 <PersonListing person={r.private_message_creator} />
39 dangerouslySetInnerHTML={mdToHtml(pmr.original_pm_text)}
43 {i18n.t("reporter")}: <PersonListing person={r.creator} />
46 {i18n.t("reason")}: {pmr.reason}
52 <T i18nKey="resolved_by">
54 <PersonListing person={resolver} />
57 <T i18nKey="unresolved_by">
59 <PersonListing person={resolver} />
67 className="btn btn-link btn-animate text-muted py-0"
68 onClick={linkEvent(this, this.handleResolveReport)}
69 data-tippy-content={tippyContent}
70 aria-label={tippyContent}
74 classes={`icon-inline ${
75 pmr.resolved ? "text-success" : "text-danger"
83 handleResolveReport(i: PrivateMessageReport) {
84 let pmr = i.props.report.private_message_report;
85 let form = new ResolvePrivateMessageReport({
87 resolved: !pmr.resolved,
88 auth: auth().unwrap(),
90 WebSocketService.Instance.send(wsClient.resolvePrivateMessageReport(form));